亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統 > iOS > 正文

iOS開發避免安全隱患的要點總結

2020-07-26 02:19:36
字體:
來源:轉載
供稿:網友

現在很多iOS的APP沒有做任何的安全防范措施,導致存在很多安全隱患和事故,今天我們來聊聊iOS開發人員平時怎么做才更安全。

一、網絡方面

用抓包工具可以抓取手機通信接口的數據。以Charles為例,用Charles可以獲取http的所有明文數據,配置好它的證書后就可以模擬中間人攻擊,獲取https加密前的明文數據。

1.1 中間人攻擊

先簡要地說下什么是中間人攻擊:

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

所以現在是:

客戶端->中間人

②然后中間人把消息轉給服務端,也就是:

中間人->服務端

③服務端把帶有公鑰的信息發送給客戶端,但是被中間截獲。所以是:

服務端-[服務端的公鑰] ->中間人

④中間人把服務端的公鑰替換成自己的公鑰,發送給客戶端,聲稱是服務端的公鑰:

中間人-[中間人的公鑰] ->客戶端

⑤客戶端用得到的公鑰加密,實際是用中間人的公鑰進行加密,所以中間人可以用自己的私鑰解密,獲取原始數據,然后再用服務端的公鑰對原始數據(或者修改原始數據內容)加密后發送給服務端。

這樣中間人就可以獲取到雙方的通信數據,并可以制造虛假數據。

1.2 如何防范中間人攻擊?

下面開始說如何防范:

1.2.1 SSL Pinning

SSL Pinning的原理就是把服務端的公鑰存到客戶端中,客戶端會校驗服務端返回的證書是否和客戶端保存的一致,這樣就避免了中間人替換證書進行的攻擊。

SSL Pinning的實現比較簡單,只需要把CA證書放入項目中,通過Security framework實現NSURLSession上的SSL Pinning。如果用的是AFNetworking,代碼更簡單一點:

這樣通過Charles抓包就會報錯。

證書驗證有可以只驗證公鑰(AFSSLPinningModePublicKey),也可以完全驗證證書(AFSSLPinningModeCertificate)。

但是用SSL Pinning有個很嚴重的問題,就是如果證書有問題,只有發布新版本才能解決。如果新版本一直審核不通過,app的網絡通信就全部掛掉了。

比如賽門鐵克(Symantec)證書被google和iOS12不信任的問題。如果app內置了證書,就必須要重新發版。

1.2.2 接口內容進行加密

很多的app接口只對請求的參數進行加密和各種驗證,而接口返回過來的數據就是明文。如果不用SSL Pinning來防止中間人攻擊,也可以把接口返回的數據也進行加密,這樣抓包工具抓到包后也依然不能破解。

比如微信,微信中的接口用的是http協議,但是內容全部進行了加密。

現在常用的是對稱加密,加密效率比較快。如果app里有的數據特別重要,還是要用非對稱加密,非對稱加密更安全,但是效率會比較慢。

二、日志 2.1 Swift日志

Swift中打印日志的語法可以用print,也可以用NSLog。但是盡量別用NSLog,因為Swift中用NSLog,系統日志中是能查到的??梢酝ㄟ^pp助手、iTools或者Xcode的Devices and Simulators 來查看系統日志。

用print打印日志就不會出現在系統日志中。

2.2 OC日志

在release環境下不要輸出NSLog日志。一般大家都會用宏定義解決,如下:

三、信息的存儲 3.1 密鑰

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

如:#define AES_KEY @“aaa123"

這樣做很容易就可以被反編譯出來。安全性比較差。可以用以下方法加強安全,增加破解的難度。

對密鑰(A)進行加密后定義為宏(B),使用的時候進行解密得到密鑰(A)。其中對密鑰A加密的密鑰為C。

因為在宏定義的時候我們如果定義成字符串,會直接存在data段,這樣破解者很容易獲取到。比較安全的做法是把C和B定義成uint8_t[]數組,這樣每個字符就會放到text段的每個單獨指令中。指令執行后生成字符串。這樣就會很安全。

用一段長文本,按規則提取出里面的密鑰,密鑰是隨機的。

在服務端和客戶端定義一段長文本,app端隨機生成起始位置和長度,把起始位置和長度進行移位等操作,生成相應的數字,對數字進行Base64編碼,生成的字符串 傳給服務端,服務端根據這個字符串 就能 解析出相關的密鑰。

代碼如下:

這樣只是增加了破解者獲取密鑰的難度,其實并不能完全阻止破解者獲取。

3.2 Keychain

越獄的iPhone可以查看導出Keychain保存的信息。Keychains的內容存放在sqlite中,目錄為:/private/var/Keychains??梢酝ㄟ^keychain-dump可以查看鑰匙串里存放的的內容。

所以保存到Keychain的數據一定要是加密之后的數據。 

3.3 plist、sqlite

plist、sqlite可以直接在ipa安裝文件中獲取到,所以不要在這些文件中存放重要信息,如果要保存,就進行加密后再存放。

四、app加固 4.1 代碼混淆

代碼混淆就是把易讀的類名、方法名替換成不易讀的名字。常用的方法有宏替換和腳本替換。

比如本來方法名為:- (void)loadNetData; 進行代碼混淆后,用class-dump導出頭文件后會顯示成修改后的方法名:- (void)showxhevaluatess;

4.2 用C語言

核心代碼用C語言寫,但是C語言的函數也可以被hook,比如用fishhook。開發人員可以用靜態內聯函數來防止hock,破解者就只能去理解代碼的邏輯。

4.3 檢測tweak

可以檢測 /Library/MobileSubstrate/DynamicLibraries 下的 plist 文件里是否包含自己app的bundle id。如果包含,可以進行限制app的功能、提示該手機不安全 等。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
yw.139尤物在线精品视频| 91亚洲精品久久久久久久久久久久| 九九热最新视频//这里只有精品| 91干在线观看| 国产精品九九久久久久久久| 亚洲精品美女久久久久| 成人免费在线视频网址| 日本视频久久久| 亚洲最大的成人网| 日本高清久久天堂| 最近2019中文字幕大全第二页| 一区二区亚洲欧洲国产日韩| 日韩精品视频在线观看网址| 国产精品久久久久aaaa九色| 中文字幕亚洲欧美日韩2019| 国产中文字幕日韩| 亚洲免费av电影| 一区二区成人av| 国产精品电影在线观看| 国产偷亚洲偷欧美偷精品| 久久视频这里只有精品| 久久精品国产欧美激情| 色悠悠久久久久| 欧美视频在线看| 国产美女扒开尿口久久久| 日本久久久久久久| 久久亚洲国产精品成人av秋霞| 亚洲日韩中文字幕| 久久中国妇女中文字幕| 亚洲人成77777在线观看网| 国产日韩欧美视频在线| 国产精品久久久久久婷婷天堂| 中文字幕精品一区久久久久| 欧美性xxxx在线播放| 亚洲成人精品视频在线观看| 中文字幕亚洲无线码a| 国产成人精品视| 九九精品在线视频| 韩国19禁主播vip福利视频| 麻豆乱码国产一区二区三区| 性金发美女69hd大尺寸| 亚洲天堂av高清| 麻豆一区二区在线观看| 一区二区在线视频播放| 日韩电影在线观看永久视频免费网站| 亚洲久久久久久久久久| 久久久亚洲国产| 午夜精品久久久久久久久久久久| 97精品国产aⅴ7777| 一区二区三区动漫| 日韩精品在线视频| 欧美日韩中文字幕在线视频| 91午夜理伦私人影院| 7m第一福利500精品视频| 久久久久久久电影一区| 日韩中文字幕精品| 国产男女猛烈无遮挡91| 亚洲一区中文字幕在线观看| 国产精品揄拍500视频| 亚洲精品欧美极品| 狠狠躁夜夜躁人人躁婷婷91| 主播福利视频一区| 国产精品免费一区| 亚洲v日韩v综合v精品v| 久久精品成人动漫| 久久九九有精品国产23| 国产精品久久久久久久av电影| 亚洲在线第一页| 亚洲欧美另类自拍| 91免费视频网站| 亚洲free嫩bbb| 中文在线资源观看视频网站免费不卡| 97视频在线观看网址| 国产成人一区二区| 中文字幕久热精品视频在线| 国产精品网站入口| 国产亚洲视频中文字幕视频| 国产成人激情小视频| 久久中文字幕视频| 一色桃子一区二区| 欧美精品日韩www.p站| 欧美床上激情在线观看| 欧美日韩国产成人| 亚洲新中文字幕| 国产精品国产自产拍高清av水多| 97香蕉超级碰碰久久免费的优势| 秋霞av国产精品一区| 日韩欧美在线播放| 98精品国产高清在线xxxx天堂| 欧洲成人在线视频| 成人黄色av网站| 亚洲va电影大全| 欧美黑人一区二区三区| 国产精品一二三在线| 亚洲四色影视在线观看| 中文字幕视频在线免费欧美日韩综合在线看| 亚洲第一天堂无码专区| 精品人伦一区二区三区蜜桃网站| 日韩av电影手机在线| 亚洲国产欧美久久| 日韩精品日韩在线观看| 久久久人成影片一区二区三区| 日韩高清a**址| 日产精品久久久一区二区福利| 日韩电影免费在线观看中文字幕| 亚洲一区二区中文字幕| www.xxxx欧美| 国产视频久久久久久久| 亚洲国产精品久久久久秋霞蜜臀| 日韩中文字幕亚洲| 日本三级久久久| 欧美男插女视频| 91中文在线视频| 久久久久国产一区二区三区| 91久久久久久久久| 国产精品影片在线观看| 成人精品福利视频| 日韩有码在线视频| 欧美激情第一页xxx| 国产日产亚洲精品| 国产国语videosex另类| 精品久久久国产精品999| 91免费看片在线| 国产精品视频内| 日韩av在线网址| 日日骚久久av| 亚洲国产精彩中文乱码av在线播放| 亚洲精品欧美一区二区三区| 亚洲天堂成人在线| 国产欧美亚洲精品| 俺也去精品视频在线观看| 国产欧美在线看| 亚洲最大成人网色| 久久青草福利网站| 亚洲专区国产精品| 亚洲天堂免费视频| 久久天堂电影网| 日韩中文视频免费在线观看| 曰本色欧美视频在线| 久久乐国产精品| 欧美日韩亚洲网| 国产精品视频一| 亚洲wwwav| 国产欧美精品va在线观看| 色久欧美在线视频观看| 日韩成人激情在线| 日韩中文字幕免费| 一本大道久久加勒比香蕉| 日韩欧美在线播放| 一区二区三区视频免费| 欧美极品美女电影一区| 最近中文字幕mv在线一区二区三区四区| 91sao在线观看国产| www国产亚洲精品久久网站| 欧美猛交免费看| 国外成人免费在线播放| 久久久视频在线| 久久五月天综合| 精品亚洲永久免费精品| 久久男人av资源网站| 国产精品无码专区在线观看| 免费99精品国产自在在线| 欧美国产极速在线| 国产精品永久免费观看|