在我們的app當(dāng)中概说,為了數(shù)據(jù)的安全,有時需要對數(shù)據(jù)進行加密震缭,iOS中常見的加密算法主要有:base64加密赂毯,MD5加密,對稱加密拣宰,非對稱加密党涕。今天我們來探討一下iOS中常見的加密算法。
網(wǎng)絡(luò)開發(fā)中中的原則:
1:在網(wǎng)絡(luò)上不允許傳輸用戶的明文隱私數(shù)據(jù)巡社。
2:在本地不允許保存用戶的明文隱私數(shù)據(jù)膛堤。
3:用戶的密碼是不可逾越的紅線。
iOS中加密算法的分類:
iOS中的加密主要分為三大類:對稱加密晌该、非對稱加密肥荔、線性散列算法
1.對稱加密:(可逆)
什么是對稱加密?
信息接收雙方都需事先知道密匙和加解密算法且其密匙是相同的气笙,之后便是對數(shù)據(jù)進行 加解密了次企。
對稱加密算法主要有DES怯晕,3DES潜圃,AES(高級密碼標(biāo)準(zhǔn),美國國家安全局使用的舟茶,iOS系統(tǒng)使用的加密方式(例如:鑰匙串))
2.非對稱加密:(可逆)
什么是非對稱加密
發(fā)送雙方A,B事先均生成一對密匙谭期,然后A將自己的公有密匙發(fā)送給B堵第,B將自己的公有密匙發(fā)送給A,如果A要給B發(fā)送消息隧出,則先需要用B的公有密匙進行消息加密踏志,然后發(fā)送給B端,此時B端再用自己的私有密匙進行消息解密胀瞪,B向A發(fā)送消息時為同樣的道理针余。
非對稱加密算法主要有:RSA,DSA凄诞,ECC
3.線性散列算法:(不可逆)
什么是線形散列算法圆雁?
只生成一串不可逆的密文,經(jīng)常用其效驗數(shù)據(jù)傳輸過程中是否經(jīng)過修改帆谍,因為相同的生成算法對于同一明文只會生成唯一的密文伪朽,若相同算法生成的密文不同,則證明傳輸數(shù)據(jù)進行過了修改汛蝙。
特點:
算法公開的
?對相同的數(shù)據(jù)加密烈涮,得到的結(jié)果是一樣的。
?對不同的數(shù)據(jù)加密窖剑,得到的結(jié)果是定長的坚洽。md5對不同的數(shù)據(jù)進行加密,得到的結(jié)果都是32個字符苛吱。
不能反算的
線性散列算法主要有:
MD5酪术,SHA,HMAC ?
下面我將在密碼學(xué)分講中分別講解各個算法的原理及其使用方法翠储。