Python MD5加密详解以及多次加密的坑

在python中可以使用hashlib这个库来使用MD5加密:

import hashlib

在使用MD5加密的使用要注意加密内容的编码格式:

import hashlib                   //导入hash库函数
md5_object = hashlib.md5()    //创建一个MD5对象
md5_object.update(b'admin')    //添加去要加密的文本
md5_result = md5_object.hexdigest()    //获取加密结果

如果文本是中文的话,需要进行编码编码,可以转为UTF-8、GBK、GB2312、GB18030,不分大小写,因为GBK/GB2312/GB18030均是针对汉字的编码,所以md5加密后结果一样。

md5_object = hashlib.md5()
md5_object.update('admin'.encode(encoding='UTF-8'))
md5_result = md5_object.hexdigest()
print(md5_result)

查看源码的解释:

  • update(arg): Update the hash object with the bytes in arg. Repeated calls
    are equivalent to a single call with the concatenation of all
    the arguments.
    update方法只接受字节数据,使用b‘admin’,或者使用encode方法,都是将数据转为二进制。

如果想要多次加密,一不小心加密结果和自己预期的不一样,例如,第一次加密后,想对第一次加密结果再次加密,然后对第二次结果再次加密,然后将第三次结果作为最终加密结果。

text = 'admin'
md5 = hashlib.md5()
md5.update(text.encode('utf-8'))
first_md5 = md5.hexdigest()
md5.update(first_md5.encode('utf-8'))
second_md5 = md5.hexdigest()
md5.update(second_md5.encode('utf-8'))
last_md5 = md5.hexdigest()

程序结果:
first_md5: '21232f297a57a5a743894a0e4a801fc3'  // 结果没错
second_md5: 'c0e024d9200b5705bc4804722636378a' // 结果错误
last_md5: '8c3bf9f4ae60758c70c0db64c6d247a8' // 结果错误

正确结果:
first_md5: '21232f297a57a5a743894a0e4a801fc3'
second_md5: 'c3284d0f94606de1fd2af172aba15bf3'
last_md5: '77e2edcc9b40441200e31dc57dbb8829'

其实仔细一看很容易理解,我们上面加密都是使用同一md5对象,其实就是第一次update,md5对象就会将加密数据存起来,然后通过hexdigest方法加密,第二次使用update,这时候是将已经存起来的加密数据和第二次update的加密数据进行相加,然后将相加后的结果进行加密,以此类推,之后的加密过程都是这样,这也解释了为什么和预期的加密结果不一样。

如果想要和预期结果一样,我们只需要每次加密就新建一个md5对象。

text = 'admin'
for i in range(3):
    md5 = hashlib.md5()
    md5.update(text.encode(encoding='UTF-8'))
    md5_result = md5.hexdigest()
    text = md5_result
print(md5_result)

Tip:

我们可以使用sql来获取MD5加密,例如:

SELECT MD5('admin')


 

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
企业泄密的途径: 1、内部人员将资料通过软盘、U盘或移动硬盘从电脑中拷出带走; 2、内部人员通过互联网将资料通过电子邮件发送到自己的邮箱; 3、将文件打印后带出; 4、将办公用便携式电脑直接带回家中; 5、电脑易手后,硬盘上的资料没有处理,导致泄密; 6、随意将文件设成共享,导致非相关人员获取资料; 7、移动存储设备共用,导致非相关人员获取资料; 8、将自己的笔记本带到公司,连上局域网,窃取资料; 9、乘同事不在,开启同事电脑,浏览,复制同事电脑里的资料; 实现方法: 采用强制加密方式,文档只要一打开就会被加密。文档被加密后,无论通过Email、FTP、QQ、MSN、U盘等方式发送到外网,都无法打开文档。 适合的文档类型: 全面支持各种文件类型动态策略,在有新的软件版本时能快速添加。不需要重新安装加密软件,也不需要人工操作,只需要在服务器更新策略文件即可。方便快捷,降低维护成本。 办公文件加密:Office文档加密,WPS文档加密,PDF文档加密等; 二维图纸加密:AutoCAD,清华英泰MDS,TeamDesigner,基于AutoCAD内核,MasterCAM,FastCAM,等图纸; 三维图纸加密:Pro/E,Solid Works,Solid Edge,CATIA,UG,Cimatron,AutoDesk Inventor,I_Deas等图纸; 设计文件加密:Photoshop,CorelDraw,AcdSee,3Dmax,Illustrator,Fireworks,Flash,Dreamweaver等图片; 源代码加密:VB、VC、ADS、Keil、PB、VB.net、PHP、ASP、C#、Java、Delphi等源代码加密

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值