python md5和AES/ECB/pkcs7加密

本文介绍Python中实现MD5和AES加密的方法。MD5部分通过hashlib库完成字符串加密;AES加密采用ECB模式并配合PKCS7填充,使用pycrypto库实现。文章还记录了安装pycrypto过程中解决vcvarsall.bat未找到问题的经验。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近遇到python下MD5和AES加密的问题,这里简单记一下:

MD5字符串加密:

#给一个字符串MD5加密
def MD5Encrypt(str):
	import hashlib
	m = hashlib.md5()
	m.update(str)
	return m.hexdigest()

AES加密,ECB模式PKS7:

#有密码的AES加密 
def Encrypt(toEncrypt, key):
	import base64
	from Crypto.Cipher import AES
	from Crypto import Random

	toEncrypt = toEncrypt.encode("utf8")#转换为UTF8编码
	key = key.encode("utf8")

	bs = AES.block_size
	pad = lambda s: s + (bs - len(s) % bs) * chr(bs - len(s) % bs)#PKS7
	iv = Random.new().read(bs)
	cipher = AES.new(key, AES.MODE_ECB, iv)#ECB模式
	
	resData1 = cipher.encrypt(pad(toEncrypt))

	resData2 = resData1.encode('hex')#转为字符串
	resData3 = resData2.upper()#全部小写

	return resData3
值得注意的是,在这里安装pycrypto时,出现vcvarsall.bat找不到的问题,查找了很久最终找到VCForPython27.msi可以彻底解决。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值