非对称加密原理及实现

1. 为什么要使用非对称加密

非对称加密提供了数据加密(防窃听)和数字签名(防篡改)这两个功能

然而这两个功能分别有更简单的实现方式: 对称加密和散列运算

那为什么还需要非对称加密呢?

小明 发送内容 "1" 和md5值(验证数据是否被篡改)给小红, 小红 发送用AES加密后的“2”给小明。 如下图:

内容“1”可以在网络的传输中被篡改成“2”,然后加生成“2”的唯一值,最后小红收到的是“2”和“2”的md5值。小红会认为信息是没有被篡改的。 只要网络中有人获得了他们的秘钥(秘钥需要传一次),就可以对小红发送的消息进行解密。如下图:

2. 什么是非对称加密?

首先说一下对称加密: 对称加密就是用同一个秘钥对数据进行加解密。

那么非对称加密:使用不同的秘钥对数据进行加解密。

小明用私钥对内容加密,同时将公钥发送到网络中, 小红通过公钥对数据进行解密。返回信息给小明的时候,用小明的公钥进行加密,然后小明通过私钥进行解密。 完成通信流程。

3.使用python 实现加密算法

安装pip install pycrypt

生成公私钥 $ ssh-keygen -t rsa -C your_email

代码连接在参考内容可获取

参考内容:

https://www.youtube.com/watch?v=OKIfTOEo7P0

https://github.com/wxnacy/study/blob/master/python/crypto_demo/rsa_cipher.py

https://github.com/wxnacy/study/blob/master/python/crypto_demo/rsa_signature.py

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值