(转)Python 用hashlib求中文字符串的MD5值
使用過hashlib庫的朋友想必都遇到過以下的錯誤吧:“Unicode-objects must be encoded before hashing”,意思是在進(jìn)行md5哈希運算前,需要對數(shù)據(jù)進(jìn)行編碼。而且在不同版本的Python下還有所不同,唉Python還需努力啊,接口和消息都很不穩(wěn)定。
hashlib.md5(data)函數(shù)中,data參數(shù)的類型應(yīng)該是bytes。也就是說我們在進(jìn)行hash前必須把數(shù)據(jù)轉(zhuǎn)換成bytes類型,對于C程序而言似乎沒有類似問題,指針強(qiáng)制轉(zhuǎn)換就OK了。
對于中文,有朋友建議轉(zhuǎn)為utf8,哭同一中文字符串在gb2312和utf8下的值顯然是不一樣的(連長度都不一樣),hash出來的md5會一樣嗎?
下面是正確的示例:
data = “你好”
m = hashlib.md5(data.encode(“gb2312”))
print(m.hexdigest())
如果需要utf8編碼下的md5&值,就該是m = hashlib.md5(data.encode(“utf8”))。還可以試試:encode(“mbcs”)、encode(“unicode_escape”)以及encode(“raw_unicode_escape”)
問題解決了,但是心頭的疑問卻更多了。為什么不能直接hashlib.md5(data),非要強(qiáng)制進(jìn)行編碼轉(zhuǎn)換,設(shè)計者的初衷何在?中文字符在Python中是以什么形式存在?
print(‘%x’%ord(data[0]))
4f60
說明中文字符在Python中是以unicode存在的。至此,所有的疑問都得以解除了。
在hash前要求進(jìn)行編碼轉(zhuǎn)換,是因為同一個字符串在不同的編碼體系下有不同的值,為確保不發(fā)生歧義必須要進(jìn)行一次顯性轉(zhuǎn)換。
總結(jié)
以上是生活随笔為你收集整理的(转)Python 用hashlib求中文字符串的MD5值的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 河南省计算机三级准考证打印入口,2016
- 下一篇: 编程方法学16:数组