iOS 數(shù)據(jù)傳輸和本地存儲(chǔ)安全

眾所周知APPLE的iOS是封閉的见妒,每個(gè)app有著沙盒路徑,正規(guī)發(fā)布途徑也只有唯一的APPStore, 但是市場(chǎng)上越獄手機(jī)和強(qiáng)大的抓包工具依然時(shí)時(shí)刻刻威脅著App 的安全郊供,而且隨著項(xiàng)目慢慢積累用戶峡碉,用戶的隱私和數(shù)據(jù)安全越來(lái)越重要。要知道危險(xiǎn)遍布于開(kāi)發(fā)的各個(gè)階段驮审,而且對(duì)安全的重視程度也間接體現(xiàn)了一個(gè)開(kāi)發(fā)者的能力和意識(shí)鲫寄。本文針對(duì)項(xiàng)目數(shù)據(jù)傳輸和本地存儲(chǔ)著兩塊,將開(kāi)發(fā)過(guò)程中涉及到和安全相關(guān)的問(wèn)題都記錄下來(lái)疯淫,作為積累地来。

數(shù)據(jù)安全傳輸

1. 關(guān)鍵字段加密

在iOS開(kāi)發(fā)過(guò)程中,抓包是常見(jiàn)的必備技能之一峡竣。我們可以使用抓包利器Charles 或者使用 Fidder 進(jìn)行抓包靠抑,在應(yīng)用進(jìn)行發(fā)送請(qǐng)求的時(shí)候,如果沒(méi)有對(duì)數(shù)據(jù)和關(guān)鍵信息進(jìn)行加密的話适掰,那么恭喜你颂碧,你的數(shù)據(jù)在網(wǎng)上裸奔了,與此同時(shí)要是有人想獲取你的隱私簡(jiǎn)直再容易不過(guò)了类浪,而且還可以篡改你的請(qǐng)求载城,讓你原本準(zhǔn)備充值 1 元的賬戶,生生變成 100元费就,甚至更多诉瓦。

所以我們需要在請(qǐng)求數(shù)據(jù)或者服務(wù)端返回?cái)?shù)據(jù)的時(shí)候需要進(jìn)行數(shù)據(jù)的加密,目前可逆的加密方法主要有:

RSA - 非對(duì)稱加密
DES - 對(duì)稱加密
AES - 對(duì)稱加密

使用 RSA 加密是最安全的力细,但加解密的時(shí)候也相應(yīng)需要較多的時(shí)間睬澡,所以建議一般加密的接口敏感數(shù)據(jù)使用 DES 或者 AES 就足夠了。

算法實(shí)現(xiàn):RSA_DES_AES加密算法 demo

2. HTTPS 協(xié)議傳輸

自蘋(píng)果宣布2017年1月1日開(kāi)始強(qiáng)制使用https以來(lái)眠蚂,htpps慢慢成為大家討論的對(duì)象之一煞聪,不是說(shuō)此前https沒(méi)有出現(xiàn),只是這一決策讓得開(kāi)發(fā)者始料未及逝慧, 雖然在2016年底昔脯,蘋(píng)果突然宣布無(wú)限期推遲這個(gè)計(jì)劃,不過(guò)隨著網(wǎng)絡(luò)世界的日益發(fā)達(dá)笛臣,將自己開(kāi)發(fā)的產(chǎn)品從 http 升級(jí)到 https 已經(jīng)是勢(shì)在必行了云稚, 最近在項(xiàng)目中已經(jīng)將 https 應(yīng)用其中,在這里記錄下來(lái)沈堡,以幫助其他開(kāi)發(fā)者快速接入 https 静陈。

詳情請(qǐng)見(jiàn): iOS https 協(xié)議 配置

本地存儲(chǔ)加密

1. 配置文件

為了存儲(chǔ)必要的數(shù)據(jù)在本地,一般情況下使用NSUserDefaults 或者使用數(shù)據(jù)庫(kù)的方式踱蛀。由于在越獄的手機(jī)上窿给,用戶可以訪問(wèn)到該項(xiàng)目的私有文件夾贵白,并且可以拿到 plist 和 db 文件,那么如果明文存儲(chǔ)敏感數(shù)據(jù)的話崩泡,那么就可以輕易獲取禁荒,危害用戶的信息隱私,解決的辦法在于角撞,需要將這些信息進(jìn)行加密之后再存儲(chǔ)呛伴,雖然這樣不能完全防止被破解,但是這樣提高了黑客的破解代價(jià)谒所。

具體的加密可以參照關(guān)鍵字段加密介紹的 RSA热康,DES 和 AES 加密算法。

最好不要使用 Base64 這種簡(jiǎn)單的加密和 md5 這種不可逆的加密劣领,當(dāng)然使用 DES 和 AES 也不是完全安全的姐军,只要黑客對(duì)你的源碼進(jìn)行解析,發(fā)現(xiàn)了加密的公鑰尖淘,依然可以破解你的信息奕锌,所以最好的方法是定期更換公鑰,或者由服務(wù)器分配公鑰村生。

2. NSLog 打印內(nèi)容緩存

為了清晰的看到接口返回的數(shù)據(jù)惊暴,或者為了定位每一步調(diào)用,相關(guān)參數(shù)的變化趁桃,有很多程序員會(huì)使用 NSLog 將數(shù)據(jù)和參數(shù)的值進(jìn)行打印辽话,而且一些第三方框架也會(huì)進(jìn)行數(shù)據(jù)打印,這些數(shù)據(jù)在程序運(yùn)行之后會(huì)在沙盒內(nèi)的 /Library/Caches 下進(jìn)行緩存卫病。建議有打印數(shù)據(jù)需求的開(kāi)發(fā)者將 NSLog 進(jìn)行封裝:

//------------------------打印日志-----------------------------
//DEBUG  模式下打印日志,當(dāng)前行
#ifdef DEBUG
#   define DLog(fmt, ...) NSLog((@"%s [Line %d] " fmt), __PRETTY_FUNCTION__, __LINE__, ##__VA_ARGS__);
#else
#   define DLog(...)
#endif

#ifdef DEBUG
#   define QXDLog(fmt, ...) NSLog((@"-------------- \n %s [Line %d] \n------------" fmt), __PRETTY_FUNCTION__, __LINE__, ##__VA_ARGS__);

#define QXDAFNErrorLog(error) NSLog((@"-------------- \n %s [Line %d] \n \n %@-------------\n"), __PRETTY_FUNCTION__, __LINE__, [[NSString alloc] initWithData:error.userInfo[@"com.alamofire.serialization.response.error.data"] encoding:NSUTF8StringEncoding]);
#else
#   define QXDLog(...)
#   define QXDAFNErrorLog(error)
#endif

然后一般的第三方框架都會(huì)有 Log 輸出等級(jí)的設(shè)置油啤,在測(cè)試完成之后,可以將其設(shè)置為不輸出 Log蟀苛,保證安全村砂。

3. SQLite數(shù)據(jù)庫(kù)文件

打開(kāi)程序目錄/Library/Caches/項(xiàng)目bundle ID/下的cache.db文件, 會(huì)發(fā)現(xiàn)這個(gè) db 文件對(duì)每個(gè)接口的請(qǐng)求返回?cái)?shù)據(jù)進(jìn)行了存儲(chǔ),當(dāng)然包括以下敏感的數(shù)據(jù)屹逛,例如:用戶登錄完成之后后臺(tái)返回的用戶信息數(shù)據(jù),用戶 Token ....這些信息是由 AFNetworking 這個(gè)框架進(jìn)行緩存的汛骂。

而這些緩存對(duì)我們都是沒(méi)有用的罕模,這個(gè)時(shí)候可以使用限制程序緩存的方式,讓這些緩存消失:

// 清除本地?cái)?shù)據(jù)請(qǐng)求緩存
NSURLCache *sharedCache = [[NSURLCache alloc] initWithMemoryCapacity:0 diskCapacity:0 diskPath:0];
[NSURLCache setSharedURLCache:sharedCache];

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末帘瞭,一起剝皮案震驚了整個(gè)濱河市淑掌,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌蝶念,老刑警劉巖抛腕,帶你破解...
    沈念sama閱讀 221,635評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件芋绸,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡担敌,警方通過(guò)查閱死者的電腦和手機(jī)摔敛,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,543評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)全封,“玉大人马昙,你說(shuō)我怎么就攤上這事∩层玻” “怎么了行楞?”我有些...
    開(kāi)封第一講書(shū)人閱讀 168,083評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)土匀。 經(jīng)常有香客問(wèn)我坑夯,道長(zhǎng)替劈,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 59,640評(píng)論 1 296
  • 正文 為了忘掉前任,我火速辦了婚禮狸吞,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘仆嗦。我一直安慰自己枝恋,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,640評(píng)論 6 397
  • 文/花漫 我一把揭開(kāi)白布携丁。 她就那樣靜靜地躺著琢歇,像睡著了一般。 火紅的嫁衣襯著肌膚如雪梦鉴。 梳的紋絲不亂的頭發(fā)上李茫,一...
    開(kāi)封第一講書(shū)人閱讀 52,262評(píng)論 1 308
  • 那天,我揣著相機(jī)與錄音肥橙,去河邊找鬼魄宏。 笑死,一個(gè)胖子當(dāng)著我的面吹牛存筏,可吹牛的內(nèi)容都是我干的宠互。 我是一名探鬼主播,決...
    沈念sama閱讀 40,833評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼椭坚,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼予跌!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起善茎,我...
    開(kāi)封第一講書(shū)人閱讀 39,736評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤券册,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體烁焙,經(jīng)...
    沈念sama閱讀 46,280評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡航邢,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,369評(píng)論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了骄蝇。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片膳殷。...
    茶點(diǎn)故事閱讀 40,503評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖乞榨,靈堂內(nèi)的尸體忽然破棺而出秽之,到底是詐尸還是另有隱情,我是刑警寧澤吃既,帶...
    沈念sama閱讀 36,185評(píng)論 5 350
  • 正文 年R本政府宣布考榨,位于F島的核電站,受9級(jí)特大地震影響鹦倚,放射性物質(zhì)發(fā)生泄漏河质。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,870評(píng)論 3 333
  • 文/蒙蒙 一震叙、第九天 我趴在偏房一處隱蔽的房頂上張望掀鹅。 院中可真熱鬧,春花似錦媒楼、人聲如沸乐尊。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,340評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)扔嵌。三九已至,卻和暖如春夺颤,著一層夾襖步出監(jiān)牢的瞬間痢缎,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,460評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工世澜, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留独旷,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,909評(píng)論 3 376
  • 正文 我出身青樓寥裂,卻偏偏與公主長(zhǎng)得像嵌洼,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子封恰,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,512評(píng)論 2 359

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