vlambda博客
学习文章列表

写给小白的常见三种加密方式:MD5,对称非对称加密

我们在做数据类传输产品或测试的过程中,总会听到开发说数据要加密,然后使用各种加密方式,那么希望通过本文,能够让大家对一些常见的加密方式有一些更加深入的了解,理解其中的底层逻辑。


今天介绍三种常见的加密方式:

1,MD5加密

2,对称加密

3,非对称加密


1,MD5加密

MD5算法的原理可简要的叙述为:MD5码以512位分组来处理输入的信息,且每一分组又被划分为16个32位子分组,经过了一系列的处理后,算法的输出由四个32位分组组成,将这四个32位分组级联后将生成一个128位散列值


总体流程如下图所示,每次的运算都由前一轮的128位结果值和当前的512bit值进行运算



MD5加密的特点:

  • 不可逆运算

  • 对不同的数据加密的结果是定长的16个字节(不管文件多大都一样)

  • 对相同的数据加密,得到的结果是一样的(也就是复制)。

  • 抗修改性 : 信息“指纹”,对原数据进行任何改动,哪怕只修改一个字节,所得到的 MD5 值都有很大区别.

  • 弱抗碰撞 : 已知原数据和其 MD5 值,想找到一个具有相同 MD5 值的数据(即伪造数据)是非常困难的.

  • 强抗碰撞: 想找到两个不同数据,使他们具有相同的 MD5 值,是非常困难的


MD5安全吗?

加解密尝试:https://www.cmd5.com/


2,对称加密

对称加密算法又称传统加密算法。加密和解密使用同一个密钥。

加密解密过程:明文->密钥加密->密文,密文->密钥解密->明文。


写给小白的常见三种加密方式:MD5,对称非对称加密

示例:

密钥:X

加密算法:每个字符+X

明文:Hello

密钥为 1时 加密结果:Ifmmp

密钥为 2时 加密结果:Jgnnq


优缺点:

  • 算法公开,计算量小,加密速度快,加密效率高 

  • 双方使用相同的钥匙,安全性得不到保证

注意事项:

  • 密钥的保密工作非常重要 

  • 密钥要求定期更换


经典对称加密算法有三种:

  • DES(Data Encryption Standard):数据加密标准,速度较快,适用于加密大量数据的场合

  • 3DES:基于DES,对一块数据用三个不同的密钥进行三次加密,强度更高

  • AES(Advanced Encryption Standard):高级加密标准,目前美国国家安全局使用的,苹果的钥匙串访问采用的就AES加密。是现在公认的最安全的加密方式,是对称密钥加密中最流行的算法。


3,非对称加密RSA

  • 对称加密算法又称现代加密算法。

  • 非对称加密是计算机通信安全的基石,保证了加密数据不会被破解。

  • 非对称加密算法需要两个密钥:公开密钥(publickey) 和私有密(privatekey)

  • 公开密钥和私有密钥是一对

如果用公开密钥对数据进行加密,只有用对应的私有密钥才能解密。 

如果用私有密钥对数据进行加密,只有用对应的公开密钥才能解密。


写给小白的常见三种加密方式:MD5,对称非对称加密


特点: 

  • 算法强度复杂,安全性依赖于算法与密钥。 

  • 加密解密速度慢。

与对称加密算法的对比:

  • 对称加密只有一种密钥,并且是非公开的,如果要解密就得让对方知道密钥。 

  • 非对称加密有两种密钥,其中一个是公开的。

RSA应用场景: 

  • 由于RSA算法的加密解密速度要比对称算法速度慢很多,在实际应用中,通常采取:

  • 数据本身的加密和解密使用对称加密算法(AES)。 

  • 用RSA算法加密并传输对称算法所需的密钥。

扩展:

数字签名

http://www.ruanyifeng.com/blog/2011/08/what_is_a_digital_signature.html



不远万里,我们一起分享!


记得点赞转发收藏吖!