App安全與加密上

加密算法分類

  • 對(duì)稱加密:加密和解密都是使用一個(gè)密鑰芦劣,密鑰的保密工作就非常重要.
  • 非對(duì)稱加密:用公鑰加密,私鑰解密; 用私鑰加密罐监,公鑰解密.

對(duì)稱加密

常見對(duì)稱加密算法

  1. DES 數(shù)據(jù)加密標(biāo)準(zhǔn)
  2. 3DES
  3. AES "高級(jí)"加密標(biāo)準(zhǔn)
  4. ECB 電子代碼本,每個(gè)塊都是獨(dú)立加密的
  5. CBC 密碼塊鏈:使用一個(gè)密鑰和一個(gè)初始化向量 (IV)對(duì)數(shù)據(jù)執(zhí)行加密轉(zhuǎn)換,可以有效地保證密文的完整性梳庆。

ECB 終端測(cè)試命令

$ openssl enc -des-ecb -K 616263 -nosalt -in msg1.txt -out msg1.bin //加密
$ openssl enc -des-ecb -K 616263 -nosalt -in msg1.bin -out msg1.txt -d //解密
$ xxd msg1.bin // 查看加密之后的二進(jìn)制文件

CBC終端測(cè)試命令

$ openssl enc -des-cbc -K 616263 -iv 0000000000000000 -nosalt -in a.txt -out msg1.bin //加密
$ openssl enc -des-cbc -K 616263 -iv 0000000000000000 -nosalt -in msg1.bin -out msg4.txt -d //解密
$ xxd msg1.bin //查看加密之后的二進(jìn)制文件
非對(duì)稱加密算法

概要

1.加密解密方法: 用公鑰解密然后用私鑰解密;或者私鑰加密然后用公鑰解密
2.優(yōu)缺點(diǎn)鳞溉,優(yōu)點(diǎn)是安全 缺點(diǎn)是速度慢

RSA原理

OpenSSL 終端命令

openssl genrsa -out private.pem 512 //生成強(qiáng)度是 512 的 RSA 私鑰
openssl rsa -in private.pem -text -out private.txt //以明文輸出私鑰內(nèi)容
openssl rsa -in private.pem -check //校驗(yàn)私鑰文件
openssl rsa -in private.pem -out public.pem -outform PEM -pubout //從私鑰中提取公鑰
$ openssl rsa -in public.pem -out public.txt -pubin -pubout -text //以明文輸出公鑰內(nèi)容
openssl rsautl -encrypt -pubin -inkey public.pem -in msg.txt -out msg.bin //使用公鑰加密小文件
openssl rsautl -decrypt -inkey private.pem -in msg.bin -out a.txt //使用私鑰解密小文件
openssl rsa -in private.pem -out private.der -outform der //將私鑰轉(zhuǎn)換成 DER 格式
openssl rsa -in public.pem -out public.der -pubin -outform der //將公鑰轉(zhuǎn)換成 DER 格式

iOS 相關(guān)證書生成命令

openssl genrsa -out ca.key 1024 //生成私鑰
openssl req -new -key ca.key -out rsacert.csr //創(chuàng)建證書請(qǐng)求
openssl x509 -req -days 3650 -in rsacert.csr -signkey ca.key -out rsacert.crt //生成證書并簽名瘾带,有效期10年
openssl x509 -outform der -in rsacert.crt -out rsacert.der //將 PEM 格式文件轉(zhuǎn)換成 DER 格式
openssl pkcs12 -export -out p.p12 -inkey ca.key -in rsacert.crt //入P12文件

安全之簽名

MD5

Hash 散列函數(shù)不可逆的特點(diǎn),是“加密”的另一種應(yīng)用穿挨,可實(shí)現(xiàn)對(duì)安全信息的簽名驗(yàn)證和標(biāo)志文件月弛。【不是正真的加密算法】

RSA

RSA算法有兩個(gè)作用一個(gè)是加密一個(gè)是數(shù)字簽名
數(shù)字簽名
發(fā)送方
"報(bào)文" HASH 得到 "報(bào)文摘要"
"報(bào)文摘要" 用公鑰加密(數(shù)字簽名) + 報(bào)文
發(fā)送給接收方
接收方
"報(bào)文" HASH 得到 "報(bào)文摘要"
"數(shù)字簽名" 用私鑰解密 判斷是否與 "報(bào)文摘要" 相同

iOS 安全特有功能

1.手機(jī)指紋科盛、密碼登錄

1 判斷是否有使用指紋或密碼驗(yàn)證: - (BOOL)canEvaluatePolicy:(LAPolicy)policy error:(NSError * __autoreleasing *)error attribute((swift_error(none)));
policy 分為: LAPolicyDeviceOwnerAuthenticationWithBiometrics 和 LAPolicyDeviceOwnerAuthentication帽衙, 前者只使用指紋,后者在指紋失敗后會(huì)彈出密碼驗(yàn)正贞绵。
2 請(qǐng)求驗(yàn)證厉萝,彈出驗(yàn)證界面 - (void)evaluatePolicy:(LAPolicy)policy localizedReason:(NSString *)localizedReason reply:(void(^)(BOOL success, NSError * error))reply;
3 驗(yàn)證結(jié)果,如果 success 是YES標(biāo)志驗(yàn)證成功榨崩,NO標(biāo)志不成功谴垫。 當(dāng)驗(yàn)證不成共時(shí),error 有:

3.1 LAErrorAuthenticationFailed - 指紋無(wú)法識(shí)別
3.2 LAErrorUserCancel --用戶點(diǎn)擊了取消
3.3 LAErrorUserFallback --用戶點(diǎn)擊了輸入密碼
3.4 LAErrorSystemCancel --系統(tǒng)取消
3.5 LAErrorPasscodeNotSet --因?yàn)槟阍O(shè)備上沒有設(shè)置密碼
3.6 LAErrorTouchIDNotAvailable --設(shè)備沒有Touch ID
3.7 LAErrorTouchIDNotEnrolled --因?yàn)槟愕挠脩魶]有輸入指紋
3.8 LAErrorTouchIDLockout --多次輸入母蛛,密碼鎖定
3.9 LAErrorAppCancel-- 比如電話進(jìn)入翩剪,用戶不可控的

2.鑰匙串:保存安全性很高的小數(shù)據(jù),他還具有一次保存彩郊,長(zhǎng)久保留【刪除應(yīng)用后還存在】的特點(diǎn)

iOS 中重要的函數(shù)

1.非對(duì)稱加密函數(shù)

SecKeyEncrypt 使用公鑰對(duì)數(shù)據(jù)加密
SecKeyDecrypt 使用私鑰對(duì)數(shù)據(jù)解密
SecKeyRawVerify 使用公鑰對(duì)數(shù)字簽名進(jìn)行驗(yàn)證
SecKeyRawSign 使用私鑰生成數(shù)字簽名

?著作權(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)離奇詭異浙巫,居然都是意外死亡金蜀,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,254評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門的畴,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)渊抄,“玉大人,你說我怎么就攤上這事苗傅∈阆撸” “怎么了?”我有些...
    開封第一講書人閱讀 152,445評(píng)論 0 341
  • 文/不壞的土叔 我叫張陵渣慕,是天一觀的道長(zhǎng)嘶炭。 經(jīng)常有香客問我,道長(zhǎng)逊桦,這世上最難降的妖魔是什么眨猎? 我笑而不...
    開封第一講書人閱讀 55,185評(píng)論 1 278
  • 正文 為了忘掉前任,我火速辦了婚禮强经,結(jié)果婚禮上睡陪,老公的妹妹穿的比我還像新娘。我一直安慰自己匿情,他們只是感情好兰迫,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,178評(píng)論 5 371
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著炬称,像睡著了一般汁果。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上玲躯,一...
    開封第一講書人閱讀 48,970評(píng)論 1 284
  • 那天据德,我揣著相機(jī)與錄音,去河邊找鬼跷车。 笑死棘利,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的朽缴。 我是一名探鬼主播善玫,決...
    沈念sama閱讀 38,276評(píng)論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼密强!你這毒婦竟也來(lái)了蝌焚?” 一聲冷哼從身側(cè)響起裹唆,我...
    開封第一講書人閱讀 36,927評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤誓斥,失蹤者是張志新(化名)和其女友劉穎只洒,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(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
  • 文/蒙蒙 一核偿、第九天 我趴在偏房一處隱蔽的房頂上張望诚欠。 院中可真熱鬧,春花似錦漾岳、人聲如沸轰绵。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,204評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)左腔。三九已至,卻和暖如春耀找,著一層夾襖步出監(jiān)牢的瞬間翔悠,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,423評(píng)論 1 260
  • 我被黑心中介騙來(lái)泰國(guó)打工野芒, 沒想到剛下飛機(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)容