python使用aes加密解密(python实现AES和RSA加解密的方法)
python使用aes加密解密
python实现AES和RSA加解密的方法本文实例为大家分享了python实现AES和RSA加解密的具体代码,供大家参考,具体内容如下
AES
AES 是一种对称加密算法,用key对一段text加密,则用同一个key对密文解密,
|
from Crypto import Random from Crypto. Hash import SHA from Crypto.Cipher import AES from Crypto.Cipher import PKCS1_v1_5 as Cipher_pkcs1_v1_5 from Crypto.Signature import PKCS1_v1_5 as Signature_pkcs1_v1_5 from Crypto.PublicKey import RSA import base64 # 秘钥 key = 'chenqichenqi1234' # 明文 raw = 'sina company11111111111111111111' # 加密 iv = Random.new().read(AES.block_size) cipher = AES.new(key, AES.MODE_CFB, iv) data = iv + cipher.encrypt(raw) # 解密 iv = data[: 16 ] cipher = AES.new(key, AES.MODE_CFB, iv) print cipher.decrypt(data[ 16 :]) |
RSA
RSA是一种公钥密码算法,RSA的密文是对代码明文的数字的 E 次方求mod N 的结果。也就是将明文和自己做E次乘法,然后再将其结果除以 N 求余数,余数就是密文。RSA是一个简洁的加密算法。E 和 N 的组合就是公钥(public key)。
对于RSA的解密,即密文的数字的 D 次方求mod N 即可,即密文和自己做 D 次乘法,再对结果除以 N 求余数即可得到明文。D 和 N 的组合就是私钥(private key)。
|
# 伪随机数生成器 random_generator = Random.new().read # rsa算法生成实例 rsa = RSA.generate( 1024 , random_generator) # 秘钥对的生成 private_pem = rsa.exportKey() public_pem = rsa.publickey().exportKey() message = "chenqi" # 公钥加密 rsakey = RSA.importKey(public_pem) cipher = Cipher_pkcs1_v1_5.new(rsakey) cipher_text = base64.b64encode(cipher.encrypt(message)) print cipher_text # 私钥解密 rsakey = RSA.importKey(private_pem) cipher = Cipher_pkcs1_v1_5.new(rsakey) text = cipher.decrypt(base64.b64decode(cipher_text), random_generator) print text |
如上,RSA算法可以实现公钥加密、私钥解密。
在C/S架构的通信中,如果Client要向Server发送一段消息:
0、Server事先生成秘钥对;
1、Client请求Server的公钥;
2、Client用公钥加密mesage,并将密文发给Server;
3、Server用私钥解密,获取明文;
如果Server要向Client发送消息,流程也是类似的。
这个例子还有个问题,Server的公钥是公开的,任何人都可以得到。Server只能保证只有自己的私钥可以解密消息,但不能识别消息的来源是不是可靠,因为任何人都可能用公钥加密一段文本发给Server,这里就涉及到数字签名。
Clinet也可以生成自己的秘钥对,请求Server时把自己的公钥带过去
0、Server事先生成秘钥对、Client也事先生成秘钥对;
1、Client请求Server的公钥;
2、Client用Server的公钥加密mesage,并将密文发给Server,随请求一起发送一个签名(Clinet用私钥加密一个签名,并同时附带上自己的公钥);
3、Server用Clinet的公钥解密出签名,并核对;
4、Server用私钥解密,获取明文;
小结
加密主要用对方的公钥,解密用自己的私钥。签名用自己的私钥,验签用对方的公钥。
加密解密:公钥加密,私钥解密
签名验签:私钥签名,公钥验签
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持开心学习网。
原文链接:https://www.cnblogs.com/chenny7/p/7693334.html
- python爬虫怎么爬取vip资源(Python网络爬虫之爬取微博热搜)
- python元组汇总(Python数据类型之Tuple元组实例详解)
- python mysql配置(详解python校验SQL脚本命名规则)
- python模块使用方法(详解python的argpare和click模块小结)
- python中random库的用法(Python minidom模块用法示例DOM写入和解析XML)
- python默认缩进设置(不归路系列:Python入门之旅-一定要注意缩进!!!推荐)
- python format的用法(Python中format格式输出全解)
- python扫描服务器端口(Python实现的对本地host127.0.0.1主机进行扫描端口功能示例)
- python图形绘制教程(python绘制漏斗图步骤详解)
- 如何用python做一个弹窗(python实现祝福弹窗效果)
- python3.x base64怎么加密解密(python3.x实现base64加密和解密)
- python豆瓣电影爬虫课程设计报告(详解python 模拟豆瓣登录豆瓣6.0)
- python如何编写判断正负数程序(Python实现判断一个整数是否为回文数算法示例)
- python3.5 tkinter教程(解决python3.5 正常安装 却不能直接使用Tkinter包的问题)
- python加密和解密(python实现对输入的密文加密)
- python标准库操作键盘(Python中捕获键盘的方式详解)
- 岳云鹏跟凤凰传奇谈心,说出了人生中最重要的三个人,这才成功(岳云鹏跟凤凰传奇谈心)
- 爱情可以当饭吃吗(爱情能当饭吃吗)
- Top 3 JSHS《运动与健康科学 英文 》跻身SCI体育学期刊世界前三(Top3JSHS运动与健康科学)
- 体坛传媒LOGO全新升级,多元发展迈出坚实步伐(体坛传媒LOGO全新升级)
- 超撩人治愈的绝美水彩,原来出自她之手 一笔一画令无数人沉醉(超撩人治愈的绝美水彩)
- 新手的勾线(新手的勾线)
热门推荐
- 织梦栏目怎么管理(织梦“模块管理”里面的“模块列表”显示空白的解决方法)
- numpy的核心是n维数组对象(利用ctypes获取numpy数组的指针方法)
- C#快速排序
- mysql是自动commit吗(详解MySQL与Spring的自动提交autocommit)
- SQL Server 批量导入数据的方法
- vue父组件怎么用子组件的数据(Vue使用v-model封装el-pagination组件的全过程)
- pyqt5 登录界面(pyqt5利用pyqtDesigner实现登录界面)
- docker 网络映射启动失败(解决docker安装完成报:bridge-nf-call-iptables is disabled问题)
- vue怎么使用element(Vue Element前端应用开发之图标的维护和使用)
- 使用vue组件开发项目(Vue记事本实例详解)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9