美文网首页
iOS 加密简单介绍

iOS 加密简单介绍

作者: Homer1ynn | 来源:发表于2016-08-19 14:10 被阅读46次

一、MD5加密

最常用的加密方法之一,把一段字符串通过相应的特征生成一段32位的数字字母组合。特点是不可逆,但是现在也不是绝对的不可逆,某些网站专门用来查询MD5码,所以某些简单的MD5码可以在这里搜到源码。所以为了使得MD5加密更加安全,便出现了“加盐”。主要“盐”足够乱,那么得到的MD5值就很难查到。

  • 1.压缩性:任意长度的数据,算出的MD5值长度都是固定的32位。
  • 2.容易计算:从原数据计算出MD5值很容易。
  • 3.抗修改性,对原数据先进性任何改动,所得到的MD5都会有很大差别。
  • 4.弱抗碰撞:已知原数据和它的MD5值,想找到一个拒用相同的MD5值得数据(即伪造数据)是非常困难的。
  • 5.强抗碰撞:想找到2个不同的数据,使他们具有相同的MD5值是非常困难的。

二、HMAC加密

此加密方法需要先生成密钥,然后再对密码进行MD5和HMAC加密,数据库中需要存放当时使用的密钥和密码加密后的密文。
在用户登陆时 再次对填入的密码用密钥进行加密 并且还要加上当前时间(精确到分钟) 再次HMAC加密,服务器里也会拿出以前存放的密文加上时间再次加密。所以就算黑客在中途截取了密码的密文 也在能在1分钟只能破译才能有效,大大加强了安全性。服务器为了考虑到网络的延迟一般会多算一种答案,如23分过来的密码 他会把23分和22分的都算一下和用户匹配只要对上一个就允许登陆。
如图 用户注册与用户登录

Paste_Image.png Paste_Image.png

三、base64加密

在MIME格式的电子邮件中,base64可以用来将binary的字节序列数据编码成ASCII字符序列构成的文本。使用时,在传输编码方式中指 定base64。使用的字符包括大小写字母各26个,加上10个数字,和加号“+”,斜杠“/”,一共64个字符,等号“=”用来作为后缀用途。
完整的base64定义可见RFC 1421和RFC 2045。编码后的数据比原始数据略长,为原来的4/3。
原理图:

Paste_Image.png

终端指令
先cd 找到当前目录
加密: $ base64 abc.png -o abc.txt
解密: $ base64 abc.txt -o 123.png -D

四、对称加密算法

优点:算法公开、计算量小、加密速度快、加密效率高、可逆
缺点:双方使用相同钥匙,安全性得不到保证
现状:对称加密的速度比公钥加密快很多,在很多场合都需要对称加密,
相较于DES和3DES算法而言,AES算法有着更高的速度和资源使用效率,安全级别也较之更高了,被称为下一代加密标准

nECB :电子代码本,就是说每个块都是独立加密的
nCBC :密码块链,使用一个密钥和一个初始化向量 (IV)对数据执行加密转换

ECB和CBC区别:CBC更加复杂更加安全,里面加入了8位的向量(8个0的话结果等于ECB)。在明文里面改一个字母,ECB密文对应的那一行会改变,CBC密文从那一行往后都会改变。

ECB终端命令:
$ openssl enc -des-ecb -K 616263 -nosalt -in msg1.txt -out msg1.bin
CBC终端命令:
$ openssl enc -des-cbc -K 616263 -iv 0000000000000000 -nosalt -in msg1.txt -out msg2.bin

五、RSA加密

RSA非对称加密算法
非对称加密算法需要两个密钥:公开密钥(publickey)和私有密钥(privatekey)
公开密钥与私有密钥是一对,如果用公开密钥对数据进行加密,只有用对应的私有密钥才能解密;如果用私有密钥对数据进行加密,那么只有用对应的公开密钥才能解密
特点:
非对称密码体制的特点:算法强度复杂、安全性依赖于算法与密钥但是由于其算法复杂,而使得加密解密速度没有对称加密解密的速度快
对称密码体制中只有一种密钥,并且是非公开的,如果要解密就得让对方知道密钥。所以保证其安全性就是保证密钥的安全,而非对称密钥体制有两种密钥,其中一个是公开的,这样就可以不需要像对称密码那样传输对方的密钥了
基本加密原理:
(1)找出两个“很大”的质数:P & Q
(2)N = P * Q
(3)M = (P – 1) * (Q – 1)
(4)找出整数E,E与M互质,即除了1之外,没有其他公约数
(5)找出整数D,使得E*D除以M余1,即 (E * D) % M = 1
经过上述准备工作之后,可以得到:
E是公钥,负责加密
D是私钥,负责解密
N负责公钥和私钥之间的联系
加密算法,假定对X进行加密
(X ^ E) % N = Y
n根据费尔马小定义,根据以下公式可以完成解密操作
(Y ^ D) % N = X

但是RSA加密算法效率较差,对大型数据加密时间很长,一般用于小数据。
常用场景:
分部要给总部发一段报文,先对报文整个进行MD5得到一个报文摘要,再对这个报文摘要用公钥加密。然后把报文和这个RSA密文一起发过去。
总部接收到报文之后要先确定报文是否在中途被人篡改,就先把这个密文用私钥解密得到报文摘要,再和整个报文MD5一下得到的报文摘要进行对比 如果一样就是没被改过。

相关文章

  • iOS 加密简单介绍

    一、MD5加密 最常用的加密方法之一,把一段字符串通过相应的特征生成一段32位的数字字母组合。特点是不可逆,但是现...

  • iOS如何使用MD5加密

    在登录注册时,经常采用MD5加密技术对密码,也用于对敏感数据进行加密。本文简单介绍了iOS中MD5加密的使用方式。...

  • iOS中常见的几种加密方式总结!

    这篇文章主要给大家介绍了关于iOS中常见的几种加密方法,其中包括 base64加密、POST加密、Token值介绍...

  • iOS中常见的几种加密方式总结!

    这篇文章主要给大家介绍了关于iOS中常见的几种加密方法,其中包括 base64加密、POST加密、Token值介绍...

  • iOS字符串NSString加密SHA/MD5(Objectiv

    2018.3.20 字符串在线加密在线加密1 iOS 简单应用创建一个NSString分类 参考链接:1.iOS ...

  • IOS 中的MD5使用

    这里简单的介绍一下,在iOS开发中,对字符串进行MD5加密的做法。 - (NSString *)stringToM...

  • ios简单加密

    WKCEncryptor Some base on encryptor MD5加密 base64加解密 AES25...

  • iOS中常见的几种加密方式总结!

    前言: 这篇文章主要给大家介绍了关于iOS中常见的几种加密方法,其中包括 base64加密、POST加密、Toke...

  • iOS开发常用的加密技术

    一些常用的加密介绍 在iOS开发中(应该说在所有的开发中),数据的安全性都是非常重要的。下面就简单的说一下数据加密...

  • iOS开发常用的加密技术

    一些常用的加密介绍 在iOS开发中(应该说在所有的开发中),数据的安全性都是非常重要的。下面就简单的说一下数据加密...

网友评论

      本文标题:iOS 加密简单介绍

      本文链接:https://www.haomeiwen.com/subject/gyybsttx.html