iOS開(kāi)發(fā)如何避免安全隱患

現(xiàn)在很多iOS的APP沒(méi)有做任何的安全防范措施,導(dǎo)致存在很多安全隱患和事故,今天我們來(lái)聊聊iOS開(kāi)發(fā)人員平時(shí)怎么做才更安全骗露。

一、網(wǎng)絡(luò)方面

用抓包工具可以抓取手機(jī)通信接口的數(shù)據(jù)怪瓶。以Charles為例,用Charles可以獲取http的所有明文數(shù)據(jù)坛吁,配置好它的證書(shū)后就可以模擬中間人攻擊劳殖,獲取https加密前的明文數(shù)據(jù)。

1.1 中間人攻擊

先簡(jiǎn)要地說(shuō)下什么是中間人攻擊:

①客戶(hù)端:“我是客戶(hù)端拨脉,給我你的公鑰” -> 服務(wù)端(被中間人截獲)哆姻。

所以現(xiàn)在是:

客戶(hù)端->中間人

②然后中間人把消息轉(zhuǎn)給服務(wù)端,也就是:

中間人->服務(wù)端

③服務(wù)端把帶有公鑰的信息發(fā)送給客戶(hù)端玫膀,但是被中間截獲矛缨。所以是:

服務(wù)端-[服務(wù)端的公鑰] ->中間人

如果你正在面試,或者正準(zhǔn)備跳槽帖旨,不妨看看我精心總結(jié)的面試資料:https://gitee.com/Mcci7/i-oser 來(lái)獲取一份詳細(xì)的大廠(chǎng)面試資料 為你的跳槽加薪多一份保障

④中間人把服務(wù)端的公鑰替換成自己的公鑰箕昭,發(fā)送給客戶(hù)端,聲稱(chēng)是服務(wù)端的公鑰:

中間人-[中間人的公鑰] ->客戶(hù)端

⑤客戶(hù)端用得到的公鑰加密解阅,實(shí)際是用中間人的公鑰進(jìn)行加密落竹,所以中間人可以用自己的私鑰解密,獲取原始數(shù)據(jù)货抄,然后再用服務(wù)端的公鑰對(duì)原始數(shù)據(jù)(或者修改原始數(shù)據(jù)內(nèi)容)加密后發(fā)送給服務(wù)端述召。

這樣中間人就可以獲取到雙方的通信數(shù)據(jù)朱转,并可以制造虛假數(shù)據(jù)。

1.2 如何防范中間人攻擊积暖?

下面開(kāi)始說(shuō)如何防范:

1.2.1 SSL Pinning

SSL Pinning的原理就是把服務(wù)端的公鑰存到客戶(hù)端中藤为,客戶(hù)端會(huì)校驗(yàn)服務(wù)端返回的證書(shū)是否和客戶(hù)端保存的一致,這樣就避免了中間人替換證書(shū)進(jìn)行的攻擊夺刑。

SSL Pinning的實(shí)現(xiàn)比較簡(jiǎn)單缅疟,只需要把CA證書(shū)放入項(xiàng)目中,通過(guò)Security framework實(shí)現(xiàn)NSURLSession上的SSL Pinning遍愿。如果用的是AFNetworking存淫,代碼更簡(jiǎn)單一點(diǎn):

這樣通過(guò)Charles抓包就會(huì)報(bào)錯(cuò)。

證書(shū)驗(yàn)證有可以只驗(yàn)證公鑰(AFSSLPinningModePublicKey)沼填,也可以完全驗(yàn)證證書(shū)(AFSSLPinningModeCertificate)纫雁。

但是用SSL Pinning有個(gè)很?chē)?yán)重的問(wèn)題,就是如果證書(shū)有問(wèn)題倾哺,只有發(fā)布新版本才能解決。如果新版本一直審核不通過(guò)刽脖,app的網(wǎng)絡(luò)通信就全部掛掉了羞海。

比如賽門(mén)鐵克(Symantec)證書(shū)被google和iOS12不信任的問(wèn)題。如果app內(nèi)置了證書(shū)曲管,就必須要重新發(fā)版却邓。

1.2.2 接口內(nèi)容進(jìn)行加密

很多的app接口只對(duì)請(qǐng)求的參數(shù)進(jìn)行加密和各種驗(yàn)證,而接口返回過(guò)來(lái)的數(shù)據(jù)就是明文院水。如果不用SSL Pinning來(lái)防止中間人攻擊腊徙,也可以把接口返回的數(shù)據(jù)也進(jìn)行加密,這樣抓包工具抓到包后也依然不能破解檬某。

比如微信撬腾,微信中的接口用的是http協(xié)議,但是內(nèi)容全部進(jìn)行了加密恢恼。

現(xiàn)在常用的是對(duì)稱(chēng)加密民傻,加密效率比較快。如果app里有的數(shù)據(jù)特別重要场斑,還是要用非對(duì)稱(chēng)加密漓踢,非對(duì)稱(chēng)加密更安全,但是效率會(huì)比較慢漏隐。

二喧半、日志

2.1 Swift日志

Swift中打印日志的語(yǔ)法可以用print,也可以用NSLog青责。但是盡量別用NSLog挺据,因?yàn)镾wift中用NSLog取具,系統(tǒng)日志中是能查到的∥獠ぃ可以通過(guò)pp助手者填、iTools或者Xcode的Devices and Simulators 來(lái)查看系統(tǒng)日志。

用print打印日志就不會(huì)出現(xiàn)在系統(tǒng)日志中做葵。

2.2 OC日志

在release環(huán)境下不要輸出NSLog日志占哟。一般大家都會(huì)用宏定義解決,如下:

三酿矢、信息的存儲(chǔ)

3.1 密鑰

大部分的程序員喜歡直接把密鑰放到宏或者常量里榨乎。

如:#define AES_KEY @“aaa123"

這樣做很容易就可以被反編譯出來(lái)。安全性比較差瘫筐∶凼睿可以用以下方法加強(qiáng)安全,增加破解的難度策肝。

對(duì)密鑰(A)進(jìn)行加密后定義為宏(B)肛捍,使用的時(shí)候進(jìn)行解密得到密鑰(A)。其中對(duì)密鑰A加密的密鑰為C之众。

因?yàn)樵诤甓x的時(shí)候我們?nèi)绻x成字符串拙毫,會(huì)直接存在data段,這樣破解者很容易獲取到棺禾。比較安全的做法是把C和B定義成uint8_t[]數(shù)組缀蹄,這樣每個(gè)字符就會(huì)放到text段的每個(gè)單獨(dú)指令中。指令執(zhí)行后生成字符串膘婶。這樣就會(huì)很安全缺前。

用一段長(zhǎng)文本,按規(guī)則提取出里面的密鑰悬襟,密鑰是隨機(jī)的衅码。

在服務(wù)端和客戶(hù)端定義一段長(zhǎng)文本,app端隨機(jī)生成起始位置和長(zhǎng)度脊岳,把起始位置和長(zhǎng)度進(jìn)行移位等操作肆良,生成相應(yīng)的數(shù)字,對(duì)數(shù)字進(jìn)行Base64編碼逸绎,生成的字符串 傳給服務(wù)端惹恃,服務(wù)端根據(jù)這個(gè)字符串 就能 解析出相關(guān)的密鑰。

代碼如下:

<figcaption></figcaption>

這樣只是增加了破解者獲取密鑰的難度棺牧,其實(shí)并不能完全阻止破解者獲取巫糙。

3.2 Keychain

越獄的iPhone可以查看導(dǎo)出Keychain保存的信息。Keychains的內(nèi)容存放在sqlite中颊乘,目錄為:/private/var/Keychains参淹∽沓可以通過(guò)keychain-dump可以查看鑰匙串里存放的的內(nèi)容。

所以保存到Keychain的數(shù)據(jù)一定要是加密之后的數(shù)據(jù)浙值。

3.3 plist恳不、sqlite

plist、sqlite可以直接在ipa安裝文件中獲取到开呐,所以不要在這些文件中存放重要信息烟勋,如果要保存,就進(jìn)行加密后再存放筐付。

四卵惦、app加固

4.1 代碼混淆

代碼混淆就是把易讀的類(lèi)名、方法名替換成不易讀的名字瓦戚。常用的方法有宏替換和腳本替換沮尿。

比如本來(lái)方法名為:- (void)loadNetData; 進(jìn)行代碼混淆后,用class-dump導(dǎo)出頭文件后會(huì)顯示成修改后的方法名:- (void)showxhevaluatess;

4.2 用C語(yǔ)言

核心代碼用C語(yǔ)言寫(xiě)较解,但是C語(yǔ)言的函數(shù)也可以被hook畜疾,比如用fishhook。開(kāi)發(fā)人員可以用靜態(tài)內(nèi)聯(lián)函數(shù)來(lái)防止hock印衔,破解者就只能去理解代碼的邏輯庸疾。

4.3 檢測(cè)tweak

可以檢測(cè) /Library/MobileSubstrate/DynamicLibraries 下的 plist 文件里是否包含自己app的bundle id。如果包含当编,可以進(jìn)行限制app的功能、提示該手機(jī)不安全 等徒溪。

作者:何繼昌

作者:宜信技術(shù)學(xué)院
鏈接:https://juejin.cn/post/6844903856531324941

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末忿偷,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子臊泌,更是在濱河造成了極大的恐慌鲤桥,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,126評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件渠概,死亡現(xiàn)場(chǎng)離奇詭異茶凳,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)播揪,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,254評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門(mén)贮喧,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人猪狈,你說(shuō)我怎么就攤上這事箱沦。” “怎么了雇庙?”我有些...
    開(kāi)封第一講書(shū)人閱讀 152,445評(píng)論 0 341
  • 文/不壞的土叔 我叫張陵谓形,是天一觀(guān)的道長(zhǎng)灶伊。 經(jīng)常有香客問(wèn)我,道長(zhǎng)寒跳,這世上最難降的妖魔是什么聘萨? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,185評(píng)論 1 278
  • 正文 為了忘掉前任,我火速辦了婚禮童太,結(jié)果婚禮上米辐,老公的妹妹穿的比我還像新娘。我一直安慰自己康愤,他們只是感情好儡循,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,178評(píng)論 5 371
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著征冷,像睡著了一般择膝。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上检激,一...
    開(kāi)封第一講書(shū)人閱讀 48,970評(píng)論 1 284
  • 那天肴捉,我揣著相機(jī)與錄音,去河邊找鬼叔收。 笑死齿穗,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的饺律。 我是一名探鬼主播窃页,決...
    沈念sama閱讀 38,276評(píng)論 3 399
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼复濒!你這毒婦竟也來(lái)了脖卖?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 36,927評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤巧颈,失蹤者是張志新(化名)和其女友劉穎畦木,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體砸泛,經(jīng)...
    沈念sama閱讀 43,400評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡十籍,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,883評(píng)論 2 323
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了唇礁。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片勾栗。...
    茶點(diǎn)故事閱讀 37,997評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖盏筐,靈堂內(nèi)的尸體忽然破棺而出械姻,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 33,646評(píng)論 4 322
  • 正文 年R本政府宣布楷拳,位于F島的核電站绣夺,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏欢揖。R本人自食惡果不足惜陶耍,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,213評(píng)論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望她混。 院中可真熱鬧烈钞,春花似錦、人聲如沸坤按。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,204評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)臭脓。三九已至酗钞,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間来累,已是汗流浹背砚作。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,423評(píng)論 1 260
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留嘹锁,地道東北人葫录。 一個(gè)月前我還...
    沈念sama閱讀 45,423評(píng)論 2 352
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像领猾,于是被迫代替她去往敵國(guó)和親米同。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,722評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容

  • 現(xiàn)在很多iOS的APP沒(méi)有做任何的安全防范措施摔竿,導(dǎo)致存在很多安全隱患和事故面粮,今天我們來(lái)聊聊iOS開(kāi)發(fā)人員平時(shí)怎么做...
    _小迷糊_997閱讀 687評(píng)論 0 5
  • 現(xiàn)在很多iOS的APP沒(méi)有做任何的安全防范措施,導(dǎo)致存在很多安全隱患和事故拯坟,今天我們來(lái)聊聊iOS開(kāi)發(fā)人員平時(shí)怎么做...
    wsj_2012閱讀 500評(píng)論 0 0
  • 這篇文章之前自己在公司的技術(shù)分享學(xué)院發(fā)表了。現(xiàn)在發(fā)到自己的博客上韭山。 現(xiàn)在很多iOS的app沒(méi)有做任何的安全防范措施...
    大河_大河閱讀 1,891評(píng)論 0 1
  • 現(xiàn)在很多iOS的APP沒(méi)有做任何的安全防范措施郁季,導(dǎo)致存在很多安全隱患和事故,今天我們來(lái)聊聊iOS開(kāi)發(fā)人員平時(shí)怎么做...
    iOS打工犭袁閱讀 1,511評(píng)論 0 5
  • 一钱磅、網(wǎng)絡(luò)方面 用抓包工具可以抓取手機(jī)通信接口的數(shù)據(jù)梦裂。以Charles為例,用Charles可以獲取http的所有明...
    Coder_LRT閱讀 1,155評(píng)論 0 2