python实现AES加密与解密
作者:niuu 时间:2022-12-08 08:18:40
AES加密方式有五种:ECB, CBC, CTR, CFB, OFB
从安全性角度推荐CBC加密方法,本文介绍了CBC,ECB两种加密方法的python实现
python 在 Windows下使用AES时要安装的是pycryptodome 模块
pip install pycryptodome
python 在 Linux下使用AES时要安装的是pycrypto模块
pip install pycrypto
CBC加密需要一个十六位的key(密钥)和一个十六位iv(偏移量)
ECB加密不需要iv
AES CBC 加密的python实现
from Crypto.Cipher import AES
from binascii import b2a_hex, a2b_hex
# 如果text不足16位的倍数就用空格补足为16位
def add_to_16(text):
if len(text.encode('utf-8')) % 16:
add = 16 - (len(text.encode('utf-8')) % 16)
else:
add = 0
text = text + ('\0' * add)
return text.encode('utf-8')
# 加密函数
def encrypt(text):
key = '9999999999999999'.encode('utf-8')
mode = AES.MODE_CBC
iv = b'qqqqqqqqqqqqqqqq'
text = add_to_16(text)
cryptos = AES.new(key, mode, iv)
cipher_text = cryptos.encrypt(text)
# 因为AES加密后的字符串不一定是ascii字符集的,输出保存可能存在问题,所以这里转为16进制字符串
return b2a_hex(cipher_text)
# 解密后,去掉补足的空格用strip() 去掉
def decrypt(text):
key = '9999999999999999'.encode('utf-8')
iv = b'qqqqqqqqqqqqqqqq'
mode = AES.MODE_CBC
cryptos = AES.new(key, mode, iv)
plain_text = cryptos.decrypt(a2b_hex(text))
return bytes.decode(plain_text).rstrip('\0')
if __name__ == '__main__':
e = encrypt("hello world") # 加密
d = decrypt(e) # 解密
print("加密:", e)
print("解密:", d)
AES ECB加密的python实现
"""
ECB没有偏移量
"""
from Crypto.Cipher import AES
from binascii import b2a_hex, a2b_hex
def add_to_16(text):
if len(text.encode('utf-8')) % 16:
add = 16 - (len(text.encode('utf-8')) % 16)
else:
add = 0
text = text + ('\0' * add)
return text.encode('utf-8')
# 加密函数
def encrypt(text):
key = '9999999999999999'.encode('utf-8')
mode = AES.MODE_ECB
text = add_to_16(text)
cryptos = AES.new(key, mode)
cipher_text = cryptos.encrypt(text)
return b2a_hex(cipher_text)
# 解密后,去掉补足的空格用strip() 去掉
def decrypt(text):
key = '9999999999999999'.encode('utf-8')
mode = AES.MODE_ECB
cryptor = AES.new(key, mode)
plain_text = cryptor.decrypt(a2b_hex(text))
return bytes.decode(plain_text).rstrip('\0')
if __name__ == '__main__':
e = encrypt("hello world") # 加密
d = decrypt(e) # 解密
print("加密:", e)
print("解密:", d)
来源:http://www.cnblogs.com/niuu/p/10107212.html
标签:python,AES,加密,解密
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
python读取TXT每行,并存到LIST中的方法
2023-08-09 06:09:20
![](https://img.aspxhome.com/file/2023/5/100925_0s.jpg)
Python Tornado批量上传图片并显示功能
2023-08-07 22:33:21
![](https://img.aspxhome.com/file/2023/3/62023_0s.jpg)
python函数的默认参数请勿定义可变类型详解
2021-07-26 06:12:53
使用Python通过win32 COM实现Word文档的写入与保存方法
2021-03-16 04:09:27
![](https://img.aspxhome.com/file/2023/6/75226_0s.jpg)
使用python opencv对畸变图像进行矫正的实现
2021-08-18 01:09:44
![](https://img.aspxhome.com/file/2023/7/124217_0s.jpg)
vue中点击切换按钮功能之点启用后按钮变为禁用
2023-07-02 16:51:56
![](https://img.aspxhome.com/file/2023/5/139805_0s.jpg)
3个常用的JS时间代码
2009-03-22 15:29:00
解析:MySQL 数据库搜索中大小写敏感性
2009-02-23 17:32:00
Python常问的100个面试问题汇总(下篇)
2023-09-23 06:30:29
golang程序进度条实现示例详解
2024-04-25 13:22:45
![](https://img.aspxhome.com/file/2023/9/134279_0s.png)
asp用正则过滤html标签
2008-01-19 16:34:00
Python 连接字符串(join %)
2021-01-13 23:30:46
Python中PyMySQL的基本操作
2024-01-15 20:57:11
moment.js 时间日期处理详解
2024-04-18 09:59:41
jmeter正则表达式的使用
2022-08-10 01:10:42
![](https://img.aspxhome.com/file/2023/2/86872_0s.png)
Mysql数据库的导入导出方式(各种情况)
2024-01-19 15:40:42
![](https://img.aspxhome.com/file/2023/6/110326_0s.png)
Python实现清除文件夹中重复视频
2023-07-25 16:20:48
![](https://img.aspxhome.com/file/2023/3/61183_0s.jpg)
python关于excel多个sheet的导入导出方式
2021-03-15 04:40:19
![](https://img.aspxhome.com/file/2023/0/130970_0s.png)
MySQL(win7x64 5.7.16版本)下载、安装、配置与使用的详细图文教程
2024-01-27 01:12:32
![](https://img.aspxhome.com/file/2023/0/124520_0s.png)
ORACLE分区表转换在线重定义DBMS_REDEFINITION
2024-01-16 00:23:18