iOS幾種加密方法

1.對(duì)稱加密的話用AES最好轩猩,蘋(píng)果系統(tǒng)肿轨,美國(guó)安全局上炎,RSA中的對(duì)稱加密都是同的AES加密

1.用戶密碼本地化的話恃逻,建議使用鑰匙串加密。使用第三方SSkeychain,
2.一些簡(jiǎn)單又機(jī)密的數(shù)據(jù)可以AES加密

1.base64加密

base64編碼是現(xiàn)代密碼學(xué)的基礎(chǔ)
基本原理:
1.原本的8個(gè)bit一組表示數(shù)據(jù)藕施,改為6個(gè)bit一組表示數(shù)據(jù)辛块,不足的部分補(bǔ)零,每?jī)蓚€(gè)0用一個(gè)=表示铅碍;

//        將數(shù)據(jù)進(jìn)行加密
//        獲取需要加密的二進(jìn)制數(shù)據(jù)
        NSData *data = [NSData dataWithContentsOfFile:@"1221211212"];
        
        NSData *base64Data = [data base64EncodedDataWithOptions:0];
        //將加密后的文件存儲(chǔ)到桌面
        [base64Data writeToFile:@"/Users/wangpengfei/Desktop/123"  atomically:YES];
        
        //解密
        //獲取加密后的文件
        NSData *base64DATA = [NSData dataWithContentsOfFile:@"/Users/wangpengfei/Desktop/123"];
        //解密加密后的二進(jìn)制數(shù)據(jù)
        NSData *baseData = [[NSData alloc]initWithBase64EncodedData:base64DATA options:0];
        

post加密

token值介紹

token:登錄令牌润绵,利用token值來(lái)判斷用戶的登錄狀態(tài),類似于MD5加密之后的長(zhǎng)字符串胞谈,用戶登錄成功之后尘盼,在服務(wù)器端會(huì)根據(jù)用戶信息生成一個(gè)唯一的值,這個(gè)值就是token值烦绳。
基本使用:
1.在服務(wù)器端會(huì)保存這個(gè)token值卿捎,以后利用這個(gè)token來(lái)檢索對(duì)應(yīng)的用戶信息,并且判斷用戶的登錄狀態(tài)径密;
2.用戶登錄成功之后午阵,服務(wù)器會(huì)將生成的token值返回給客戶端,在客戶端也會(huì)保存這個(gè)token值享扔。
3.以后客戶端在發(fā)送新的網(wǎng)絡(luò)請(qǐng)求的時(shí)候底桂,會(huì)默認(rèn)自動(dòng)附帶這個(gè)token值。服務(wù)器拿到客戶端傳遞的token值跟保存在數(shù)據(jù)庫(kù)的token值對(duì)比惧眠,以此判斷用戶的身份籽懦。

3.MD5加密

把一個(gè)任意長(zhǎng)度的字節(jié)串變換成一定長(zhǎng)度的十六進(jìn)制的大整數(shù)。
注意氛魁,字符串的轉(zhuǎn)換過(guò)程是不可逆的暮顺,不能通過(guò)加密結(jié)果厅篓,反向推導(dǎo)內(nèi)容基本介紹
需要導(dǎo)入第三方框架:NSString+Hash

MD5特點(diǎn):

1.壓縮性:任意長(zhǎng)度的數(shù)據(jù),算出的MD5值長(zhǎng)度都是固定的捶码。
2.容易計(jì)算:從源數(shù)據(jù)計(jì)算出來(lái)的MD5值很容易羽氮;
3.抗修改性:對(duì)原數(shù)據(jù)進(jìn)行任何改動(dòng),哪怕只修改一個(gè)字節(jié)惫恼,所得到的MD5值都有很大區(qū)別乏苦;
4.弱抗碰撞:已有原數(shù)據(jù)和其MD5值,想找到一個(gè)具有相同MD5值的數(shù)據(jù)是非常困難的尤筐;
5.強(qiáng)抗碰撞:想找到兩個(gè)不同數(shù)據(jù),使他們具有相同的MD5值是非常困難的洞就。

MD5應(yīng)用:
一致性驗(yàn)證:MD5將整個(gè)文件當(dāng)做一個(gè)大文本信息盆繁,通過(guò)不可逆的字符串變換算法,產(chǎn)生一個(gè)唯一的MD5信息摘要旬蟋,就像每個(gè)人都有獨(dú)一無(wú)二的指紋油昂,MD5對(duì)任何文件產(chǎn)生一個(gè)獨(dú)一無(wú)二的數(shù)字指紋。
利用MD5來(lái)進(jìn)行文件校驗(yàn)倾贰,被大量應(yīng)用在軟件下載站冕碟,論壇數(shù)據(jù)庫(kù),系統(tǒng)文件安全等方面

時(shí)間戳密碼

基本介紹:
動(dòng)態(tài)密碼:相同的密碼明文+相同的加密算法->英文每次登錄時(shí)間都不同匆浙,所以計(jì)算出的結(jié)果也都不相同安寺,可以充分保證密碼的安全性。
服務(wù)器會(huì)計(jì)算兩個(gè)時(shí)間值首尼,當(dāng)期時(shí)間和前一分鐘的時(shí)間(比如第59秒發(fā)送的網(wǎng)絡(luò)請(qǐng)求一秒鐘后服務(wù)器收到并作出響應(yīng)挑庶,這時(shí)服務(wù)器當(dāng)前時(shí)間比客戶端發(fā)送時(shí)間晚一分鐘,仍然能夠判斷準(zhǔn)確的值)

鑰匙串訪問(wèn)

基本介紹:
1.蘋(píng)果7.0.3版本以后公布鑰匙串訪問(wèn)的SDK.鑰匙串訪問(wèn)接口是純C語(yǔ)言的软能。
2.鑰匙串使用AES 256加密算法迎捺,能夠保證用戶密碼的安全;
3.鑰匙串訪問(wèn)的第三方框架SSKeychain,是對(duì)C語(yǔ)言框架的封裝查排。
4.鑰匙串訪問(wèn)的密碼保存在哪里凳枝?只有蘋(píng)果才知道

指紋識(shí)別

簡(jiǎn)單介紹
1.指紋識(shí)別功能是ipone 5S之后推出的SDK是iOS8推出
需要導(dǎo)入框架#import <LocalAuthentication/LocalAuthentication.h>

2.用base64編碼之后,數(shù)據(jù)長(zhǎng)度會(huì)變大跋核,增加大約1/3左右岖瑰。(8-6)/6可進(jìn)行反向解密

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市砂代,隨后出現(xiàn)的幾起案子锭环,更是在濱河造成了極大的恐慌,老刑警劉巖泊藕,帶你破解...
    沈念sama閱讀 221,695評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件辅辩,死亡現(xiàn)場(chǎng)離奇詭異难礼,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)玫锋,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,569評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門(mén)蛾茉,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人撩鹿,你說(shuō)我怎么就攤上這事谦炬。” “怎么了节沦?”我有些...
    開(kāi)封第一講書(shū)人閱讀 168,130評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵键思,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我甫贯,道長(zhǎng)吼鳞,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 59,648評(píng)論 1 297
  • 正文 為了忘掉前任叫搁,我火速辦了婚禮赔桌,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘渴逻。我一直安慰自己疾党,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,655評(píng)論 6 397
  • 文/花漫 我一把揭開(kāi)白布惨奕。 她就那樣靜靜地躺著雪位,像睡著了一般。 火紅的嫁衣襯著肌膚如雪梨撞。 梳的紋絲不亂的頭發(fā)上茧泪,一...
    開(kāi)封第一講書(shū)人閱讀 52,268評(píng)論 1 309
  • 那天,我揣著相機(jī)與錄音聋袋,去河邊找鬼队伟。 笑死,一個(gè)胖子當(dāng)著我的面吹牛幽勒,可吹牛的內(nèi)容都是我干的嗜侮。 我是一名探鬼主播,決...
    沈念sama閱讀 40,835評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼啥容,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼锈颗!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起咪惠,我...
    開(kāi)封第一講書(shū)人閱讀 39,740評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤击吱,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后遥昧,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體覆醇,經(jīng)...
    沈念sama閱讀 46,286評(píng)論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡朵纷,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,375評(píng)論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了永脓。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片袍辞。...
    茶點(diǎn)故事閱讀 40,505評(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,873評(píng)論 3 333
  • 文/蒙蒙 一盐类、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧呛谜,春花似錦在跳、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,357評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至聚凹,卻和暖如春割坠,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背妒牙。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,466評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工彼哼, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人湘今。 一個(gè)月前我還...
    沈念sama閱讀 48,921評(píng)論 3 376
  • 正文 我出身青樓敢朱,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親摩瞎。 傳聞我的和親對(duì)象是個(gè)殘疾皇子拴签,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,515評(píng)論 2 359

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

  • 本文中所有代碼演示均有GitHub源碼,點(diǎn)擊下載 普通加密方法是講密碼進(jìn)行加密后保存到用戶偏好設(shè)置中 鑰匙串是以明...
    si1ence閱讀 39,931評(píng)論 20 197
  • 加密原則: 一:對(duì)稱加密的話用AES最好旗们,蘋(píng)果系統(tǒng)(鑰匙串也是用的AES加密)蚓哩,美國(guó)安全局,RSA中的對(duì)稱加密用的...
    謝謝生活閱讀 3,360評(píng)論 2 9
  • iOS 幾種加密方法2017-06-19 [iOS開(kāi)發(fā)] iOS常見(jiàn)的幾種加密方法 普通加密方法是講密碼進(jìn)行加密后...
    WeekDiffculty閱讀 734評(píng)論 0 1
  • 普通加密方法是講密碼進(jìn)行加密后保存到用戶偏好設(shè)置中 鑰匙串是以明文形式保存喜颁,但是不知道存放的具體位置 一. bas...
    Bo_cake閱讀 566評(píng)論 0 2
  • 普通加密方法是講密碼進(jìn)行加密后保存到用戶偏好設(shè)置中 鑰匙串是以明文形式保存,但是不知道存放的具體位置 一. bas...
    奮斗ing0310閱讀 822評(píng)論 0 1