app 安全(一): 代碼混淆防止反編譯查看真實的頭文件函數聲明

??本文內容

  • 一)為什么要進行代碼混淆
  • 二)代碼混淆的兩種方法(①宏替換 ②腳本實現替換)本文github地址,敬請star
  • 三)代碼混淆參考的博客及說明

??1)為什么要進行代碼混淆?

iOS 的任何app都可以使用classdump對原程序進行dump,可以dump出所有源程序的函數所有信息:源程序所有函數類型,變量全部泄露。這樣的話,讓攻擊者,也就是黑客們了解了程序結構方便逆向。因為在工程中,我們這些變量或函數命名都是有一定可讀性的,例如跟用戶名相關的,那一般里面會有 userName,跟密碼相關的一般會有 passWord,這樣定義也是為了我們自己代碼可讀性更強,我們修改的時候才更加的方便。但是我們相信,這么個定義法,我們只是希望方便我們自己,我們可不希望方便黑客們去破解我們的APP。
如果我們把自己的程序打包為ipa 使用class-dump ,dump出程序的所有頭文件可以看到所有的頭文件,打開頭文件就可以看到所有的變量和函數了:

執行dump

代碼沒混淆反編譯結果,.h文件中函數如下圖所示


代碼沒混淆的反編譯結果

代碼混淆反編譯結果,.h文件中函數如下圖所示


代碼混淆后的反編譯結果

也許你會問,對微信和支付寶看看他們的頭文件可不可以呢?當然也是可以的,具體怎么做 參考我的這篇博客iOS 逆向導出app的頭文件(逆向工程書籍補充),當然你也可以找更好的博客,看看微信的iOS開發人員函數命名是否規范,我看過,少數也是不規范的,大部分還是比較規范的!
為了阻止別人使用逆向工程修改我們的代碼需要做反編譯,微信的代碼很多是沒有反編譯的。反向工程會帶來許多問題,諸如知識產權泄露,程序弱點暴露易受攻擊等。
很多人實現 企業微信簽到反編譯, 用Hopper搞定Mac迅雷的會員以及離線下載功能等等逆向工程的文章,這些逆向之所以成功,是因為這些微信和迅雷的實現這些功能的核心代碼沒有進行代碼混淆,如果進行了代碼混淆,即使逆向了,找不到實現功能的函數,無法修改這些函數,就無法實現用Hopper搞定Mac迅雷的會員以及離線下載功能了。
為什么做混淆 ?還有更重要的原因:某一天某安全公司給你發一份安全測試報告,你的代碼沒做混淆(當然不只這一個風險),存在安全風險,boss 聽說有風險肯定讓你解決這個問題啊,我們公司就是這樣的情況,我才做的的代碼混淆的!!
如何進行代碼混淆,經過我查閱資料,發現有兩種方法,一種簡單較low,一種復雜點檔次高點!下面介紹代碼混淆的兩種方法

??2代碼混淆的兩種方法

2.1簡單的宏替換(很簡單也有一點點low)

2.1.1

打開項目新建ConfuseReplace.h 文件,把需要替換的函數名使用#define就可以(本方法其實可以用這一句就可以說完的)

#ifndef ConfuseReplace_h
#define ConfuseReplace_h]

#define sample        XZwTFgszVxFieZta
#define seg1        mviuwjseJZYYamwu
#define zheshi     uNCrcYEobhpPGLuf
#define xxxxxx     achfhhffhhfh

#endif /* ConfuseReplace_h */

2.1.2

controller.h文件中

@interface ViewController : UIViewController

-(void)sample;
-(void)seg1:(NSString *)string seg2:(NSUInteger)num;
-(void)zheshi:(NSString *)string seg2:(NSUInteger)num;

- (void)xxxxxx;

@end

controller.m文件中

-(void)sample{  
}

-(void)seg1:(NSString *)string seg2:(NSUInteger)num{
}
-(void)zheshi:(NSString *)string seg2:(NSUInteger)num{
   
}
- (void)xxxxxx{ 
}

上面已經搞定了代碼混淆,就是這么簡單.每個函數名的串都是宏定義好的,也許有人會問,人家拿到了ConfuseReplace.h文件,那這么替換豈不是白搭,人家知道那個函數名和那個字符串對應啊,經筆者親自驗證,宏定義的字符串使用class-dump 是dump 不出來的,所以我們就放心的用

我們使用代碼混淆讓別人使用class-dump 反編譯出我們的方法名是亂碼,達到混淆的目的,混淆之后黑客使用class-dump 出你的頭文件不知道你這個函數是做什么,就不能修改你的功能 ,使用這種混淆方法class-dump 后的頭文件如下,
使用class-dump需要先安裝class-dump,如何安裝class-dump見這篇文章iOS逆向工程-----class-dump,有如何安裝class-dump和使用class-dump
導出.h文件的過程如下圖所示

導出頭文件替換的方式.gif

查看導出的頭文件

導出的頭文件查看.gif
- (void)XZwTFgszVxFieZta;
- (void)achfhhffhhfh;
- (void)didReceiveMemoryWarning;
- (void)mviuwjseJZYYamwu:(id)arg1 seg2:(unsigned long long)arg2;
- (void)uNCrcYEobhpPGLuf:(id)arg1 seg2:(unsigned long long)arg2;

這種方法的demo見我的github中的confuseDemo這個文件夾.其實說這么多大家看一下Demo秒懂,唯一的難點是需要學習下class-dump導出頭文件來驗證是否混淆成功!教程都給你鏈接了,學不學就看你啦!

2.2使用腳本替換方法名(很簡單也有一點點low)

第一、新建一個工程,在工程項目路徑中建立一個confuse.sh、一個func.list文件先打開終端,然后 cd 到你的項目工程路徑下:


cd 到項目工程路徑下然后創建兩個文件,一個 confuse.sh,一個 func.list:

注意點,不按照下面兩個操作,運行腳本會報錯:
目錄結構不要錯

層級目錄不要錯

創建兩個文件這時候我們打開這個工程文件夾,可以看到,這兩個文件已經創建好了:



我們創建的兩個文件打開工程,把剛才創建的兩個文件加進去,右鍵你的項目藍色標志,然后選擇 Add Files to...:


添加到工程中

添加進去了:


成功添加點擊 confuse.sh(confuse.sh,和func.list必須添加到NSUTest目錄下)發現還是空白的,什么都沒有,現在要在這上面加上代碼了:

需要添加的代碼原腳本代碼出自:http://blog.csdn.net/yiyaaixuexi/article/details/29201699
第二、在 .pch 文件中添加代碼不要跟我說你的工程沒有 .pch 文件,如果真沒有,自行百度,這應該算是標配,常識來的。

#ifdef __OBJC__  #import <UIKit/UIKit.h> 
 #import <Foundation/Foundation.h>  
//添加混淆作用的頭文件(這個文件名是腳本confuse.sh中定義的) 
 #import "codeObfuscation.h" #endif

寫到這里,編譯的時候是不是發現報錯啦?剛才的 .pch 文件里面的添加的代碼居然報錯了:



報錯了!不要慌,先把那句報錯的先給注釋掉:



先注釋掉報錯的這一行代碼然后我們繼續往下走!
第三、配置 Build Phase1:添加 Run Script

添加 Run Script

2:配置好 Run Script


配置好 Run Script然后再回到終端,同樣先 cd 到工程目錄下,接著我們要打開剛才 .sh 這個腳本文件的運行權限,因為默認是沒有這個權限的,在終端輸入以下指令:

打開運行權限回車,搞定,回到我們的工程,先 command + b 編譯一下工程,然后再把我們剛剛注釋掉的那句代碼解開:

打開剛剛被我們注釋掉的代碼再次 command + b 編譯,現在是不是編譯通過啦?剛剛報錯的,現在解決了!
基本上就搞定了,剩下的就是添加上我們想要混淆的變量名或函數名
第四、在 func.list 文件里,寫入待混淆的函數名如果像下面這幾個屬性跟函數:

需要混淆的屬性跟函數名那么就這在 fun.list 就這么列出來就好了:

列出需要混淆的,大功告成!現在 command + b 運行一下,然后在哪里看結果呢,請看這里:

運行結果可能這么看有點麻煩,那來個簡單一點的:

查看哈哈,你會發現,多了好多宏定義,其實就是我們剛才的字段來的:

結果當然,這也只是最簡單的代碼混淆而已,APP安全還是有很多需要注意的。一步一步來吧!
最后需要說明,出現下圖所示的這里并不一定說明代碼混淆成功,只能說明你的腳本運行成功,.pch文件中一定要導入#import "codeObfuscation.h"最好對自己混淆的代碼 打包成ipa進行dump,查看你混淆的頭文件的函數名是不是隨機的字符串了.
Snip20160816_11.png

??github地址和Demo中的各個文件夾用途說明

demo文件目錄

對上圖中的各個文件夾說明如下:

  • class dump header of confuseDemo:
    里面放的是對confuseDemo(進行了混淆)打包為ipa,再執行class-dump,dump 出來的所有的頭文件
  • class dump header of Demo2 confuse success
    里面放的是對Demo2(進行了混淆)打包為ipa,再執行class-dump,dump 出來的所有的頭文件
  • class dump header of Demo2 not confuse success
    里面放的是對Demo2(沒有進行混淆)打包為ipa,再執行class-dump,dump 出來的所有的頭文件
  • confuseDemo
    使用宏定義替換的demo,直接參考,移植到自己的工程就行
  • confuseDemo ipa
    對confuseDemo 打包為ipa了,你可以使用里面的confuseDemo.app文件進行class-dump
  • Demo2
    使用腳本進行代碼混淆的demo ,你可以參考,移植到自己的工程中

本文github地址,敬請star!

本文參考博客:

念茜女神的代碼混淆博客腳本是她提供的
iOS 對源代碼進行混淆本文的部分內容在這篇的基礎上更改的,原文只有一種方法,我這里提供了兩種,原文沒Demo,我提供了兩種方法的Demo,對Class-dump等部分內容作了更多說明,站在別人的肩膀上一步步的優化完善的哈,才出來了本文!

??appstore審核問答群:369250107,建了個倉庫:,github專門解決蘋果拒絕各種問題匯總的倉庫


最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 227,533評論 6 531
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,055評論 3 414
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 175,365評論 0 373
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,561評論 1 307
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,346評論 6 404
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 54,889評論 1 321
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 42,978評論 3 439
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,118評論 0 286
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,637評論 1 333
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,558評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,739評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,246評論 5 355
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 43,980評論 3 346
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,362評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,619評論 1 280
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,347評論 3 390
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,702評論 2 370

推薦閱讀更多精彩內容