Python 用hashlib求中文字串的MD5值

來源:互聯網
上載者:User

使用過hashlib庫的朋友想必都遇到過以下的錯誤吧:“Unicode-objects must be encoded before hashing”,意思是在進行md5雜湊運算前,需要對資料進行編碼。而且在不同版本的Python下還有所不同,唉Python還需努力啊,介面和訊息都很不穩定。

hashlib.md5(data)函數中,data參數的類型應該是bytes。也就是說我們在進行hash前必須把資料轉換成bytes類型,對於C程式而言似乎沒有類似問題,指標強制轉換就OK了。

對於中文,有朋友建議轉為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),非要強制進行編碼轉換,設計者的初衷何在?中文字元在Python中是以什麼形式存在?
print('%x'%ord(data[0]))
4f60

說明中文字元在Python中是以unicode存在的。至此,所有的疑問都得以解除了。
在hash前要求進行編碼轉換,是因為同一個字串在不同的編碼體系下有不同的值,為確保不發生歧義必須要進行一次顯性轉換。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.