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,加密,解密
0
投稿

猜你喜欢

  • python读取TXT每行,并存到LIST中的方法

    2023-08-09 06:09:20
  • Python Tornado批量上传图片并显示功能

    2023-08-07 22:33:21
  • python函数的默认参数请勿定义可变类型详解

    2021-07-26 06:12:53
  • 使用Python通过win32 COM实现Word文档的写入与保存方法

    2021-03-16 04:09:27
  • 使用python opencv对畸变图像进行矫正的实现

    2021-08-18 01:09:44
  • vue中点击切换按钮功能之点启用后按钮变为禁用

    2023-07-02 16:51:56
  • 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
  • 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
  • Mysql数据库的导入导出方式(各种情况)

    2024-01-19 15:40:42
  • Python实现清除文件夹中重复视频

    2023-07-25 16:20:48
  • python关于excel多个sheet的导入导出方式

    2021-03-15 04:40:19
  • MySQL(win7x64 5.7.16版本)下载、安装、配置与使用的详细图文教程

    2024-01-27 01:12:32
  • ORACLE分区表转换在线重定义DBMS_REDEFINITION

    2024-01-16 00:23:18
  • asp之家 网络编程 m.aspxhome.com