看代码:
>>> import hashlib >>> md5=hashlib.md5() >>> md5.update( '123' .encode( 'utf-8' )) >>> print(md5.hexdigest()) 202cb962ac59075b964b07152d234b70 >>> md5.update( '123' .encode( 'utf-8' )) >>> print(md5.hexdigest()) 4297f44b13955235245b2497399d7a93 //有没有发现 和上面对字符串“123”md5加密后的结果不一样 |
经过测试发现 md5.update 会将每次字符串拼接,我们看下 “123123”的结果如下:
>>> md 5 =hashlib.md 5 () //重新定义md 5 >>> md 5 .update( '123123' .encode( 'utf-8' )) >>> print (md 5 .hexdigest()) 4297 f 44 b 13955235245 b 2497399 d 7 a 93 //发现 123123 和上面的结果一样 就验证了 md 5 .update 是拼接的效果 |
为了防止这种干扰我们每次都要重新实例化:
每次使用update之前都要重新定义:md5=hashlib.md5()
eg:
import hashlib f = open( 'top10.md5.txt' , 'w' ) p = open( 'top10.txt' , 'r' ) for i in p: md5 = hashlib.md5() i=i.strip() //过滤空白字符 md5.update(i.encode( 'utf-8' )) c=md5.hexdigest() c=c+ '\n' f.write(c) |
====top10.txt======= 123456 password 12345678 qwerty 12345 123456789 1234567 1234567890 abc123 111111 =====top10.md5.txt=== e10adc3949ba59abbe56e057f20f883e 5f4dcc3b5aa765d61d8327deb882cf99 25d55ad283aa400af464c76d713c07ad d8578edf8458ce06fbc5bb76a58c5ca4 827ccb0eea8a706c4c34a16891f84e7b 25f9e794323b453885f5181f1b624d0b fcea920f7412b5da7be0cf42b8c93759 e807f1fcf82d132f9bb018ca6738a19f e99a18c428cb38d5f260853678922e03 96e79218965eb72c92a549dd5a330112 |
点击查看更多内容
为 TA 点赞
评论
共同学习,写下你的评论
评论加载中...
作者其他优质文章
正在加载中
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦