RSA的加密和签名

丶灬走出姿态 提交于 2019-11-26 17:15:37

RSA加密(防泄漏)

1:A(如:客户端)在本地生成私钥和公钥
2:A将公钥发给B(如:服务器)
3:B使用公钥加密后,将密文返回给A
4:A使用本地的私钥解密

防泄漏的原理:
由于私钥存在本地传输内容是公钥和密文,即使中途被黑客截获,也无法解密。

RSA签名(防篡改)

1:A生成私钥和公钥,公钥公开,私钥签名(加密)
2:A将明文、签名发给B
2:B使用公开的公钥验签(解密),验签结果和明文一致,则证明内容没被黑客篡改过。

防篡改的原理:
由于公钥是公开的, 并且只能用来开对应私钥的锁,因此,即使黑客篡改了明文没有私钥对明文进行重新签名,所以B通过验签比对即可发现明文已经被篡改。

为什么要公开:
如果公钥不是公开的,而是和明文、签名一起发出,那么黑客即可通过自己的私钥进行篡改公钥、明文以及签名。

同时防泄漏和防篡改

结合二者,A和B分别生成密钥对(公钥a1,私钥a2)和密钥对(公钥b1,私钥b2),A发出公钥a1给B解密或验签,B同样发出公钥b1给A解密或验签,即可保证更大限度的安全。简单来说,这便是一个交换公钥的过程

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!