起步
对于一些字符,python2和python3的md5加密出来是不一样的.
# python2.7 pwd = "xxx" + chr(163) + "fj" checkcode = hashlib.md5(pwd).hexdigest() print checkcode # ea25a328180680aab82b2ef8c456b4ce # python3.6 pwd = "xxx" + chr(163) + "fj" checkcode = hashlib.md5(pwd.encode("utf-8")).hexdigest() print(checkcode) # b517e074034d1913b706829a1b9d1b67
按代码差异来将,就是在python3
中需要对字符串进行 encode
操作,如果没有则会报错:
checkcode = hashlib.md5(pwd).hexdigest() TypeError: Unicode-objects must be encoded before hashing
这是因为加密时需要将字符串转化为 bytes
类型,3默认编码是 utf-8
.所以我用utf-8进行解码.
分析
如果字符串中没有 chr(163)
,那么两个版本结果是一致的,也就是说问题出在这个chr(163)
中:
# python2.7 > chr(163) '\xa3' # python3.6 > chr(163) '\xa3'
在这里说明通过 chr
得到的结果是一致的, 将它转为 bytes
类型看看:
# python2.7 > bytes(chr(163)) '\xa3' # python3.6 > chr(163).encode() b'\xc2\xa3'
python3中,在 num<128
的时候,使用 chr(num).encode('utf-8')
得到的是 一个
字符的ascii十六进制,而 num>128
的时候,使用 chr(num).encode('utf-8')
得到的是 两个
字节的ascii十六进制.
解决
改用 latin1
编码进行解码:
# python3.6 pwd = "xxx" + chr(163) + "fj" checkcode = hashlib.md5(pwd.encode("latin1")).hexdigest() print(checkcode) # ea25a328180680aab82b2ef8c456b4ce
额外
为什么是 latin1
编码呢.答案还是挺有意思的.
先说chr函数,通过 help(chr)
可以查看:
chr(...) chr(i) -> Unicode character Return a Unicode string of one character with ordinal i; 0 <= i <= 0x10ffff.
意思是它返回Unicode编码中指定位置的一个字符.python3内部也是用Unicode表示左右字符,即str类型.而通过encode
后会编码成 bytes
类型.
ascii编码中每个字符编码是一个byte,但只有1-127. 超过的部分128-255则属于 Extended ASCII
,python3 中默认的ascii中不包含这部分,所以如果执行 chr(163).encode("ascii") 就会报错 'ascii' codec can't encode character '\xa3' in position 3: ordinal not in range(128)
因此需要一个含有128-255中的部分字符的编码,且采用1个Byte固定大小编码,比如ISO 8859-1
,也就是 latin1
.当然还有其他编码如cp1252
也包含这些字符的.
python,md5
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。