您好,登錄后才能下訂單哦!
在python3的標準庫中,已經移除了md5,而關于hash加密算法都放在hashlib這個標準庫中,如SHA1、SHA224、SHA256、SHA384、SHA512和MD5算法等。
另:在網上找關于python的md5加密,發現要不是比較舊的不適用當前py版本的文章,或者是說得不夠清楚的文章,所以還是自己去看下官方文檔比較好,順便整理下關于md5的使用方法。
對于學習任何一門程序類知識,我都認為去看官方文檔這種學習方式最有效的之一,只不過一般這些文檔都是英文版的,對于一些學習者來說可能會有一定門檻,但習慣于閱讀英文文章,是非常重要的。
建議直接閱讀python3的hashlib文檔:
https://docs.python.org/3/library/hashlib.html?highlight=hashlib#credits
在hashlib庫的hash算法中,提供了很多加密算法,有 sha1()、sha224()、sha256()、sha384()、sha512()、blake2b()和 blake2s()、md5(),這些方法都通過統一接口返回一個對象,例如,使用sha256()可以創建一個SHA-256的哈希對象。
當然,進行md5加密算法,就要用到md5()方法:
>>> import hashlib >>> m = hashlib.md5() >>> m.update(b'123') >>> m.hexdigest() '202cb962ac59075b964b07152d234b70' # 或者可以這樣 >>> hashlib.md5(b'123').hexdigest() '202cb962ac59075b964b07152d234b70' # 也可以使用hash.new()這個一般方法 >>> hashlib.new('md5', b'123').hexdigest() '202cb962ac59075b964b07152d234b70'
以上是對于英文進行md5加密的,如果要對中文進行加密,發現按照上面來寫會報錯,原因在于字符轉碼問題,要如下寫:
>>> import hashlib >>> data = '你好' >>> hashlib.md5(data.encode(encoding='UTF-8')).hexdigest() '7eca689f0d3389d9dea66ae112e5cfd7'
此處先將數據轉換成UTF-8格式的,使用網上工具對比下加密的結果,發現有的md5加密工具并不是使用UTF-8格式加密的。
經測試目前發現可以轉為UTF-8、GBK、GB2312、GB18030,不分大小寫(因為GBK/GB2312/GB18030均是針對漢字的編碼,所以md5加密后結果一樣)。
除了這些編碼格式之外,還會有其他編碼的,目前還沒發現,等各位補充。
看下面實例:
>>> hashlib.md5('你好'.encode(encoding='UTF-8')).hexdigest() '7eca689f0d3389d9dea66ae112e5cfd7' >>> hashlib.md5('你好'.encode(encoding='GBK')).hexdigest() 'b94ae3c6d892b29cf48d9bea819b27b9' >>> hashlib.md5('你好'.encode(encoding='GB2312')).hexdigest() 'b94ae3c6d892b29cf48d9bea819b27b9' >>> hashlib.md5('你好'.encode(encoding='GB18030')).hexdigest() 'b94ae3c6d892b29cf48d9bea819b27b9'
如果你僅僅查md5的寫法,看上面實例就夠了;
如果你是python新手,想了解這些方法的意思和用法,繼續看下面內容。
解析
1. hashlib.new(name[, data])方法
這是個一般性方法。
name傳入的是哈希加密算法的名稱,如md5;
data傳入的是需要加密的數據,可忽略,在之后update()中傳入。
>>> m = hashlib.new('md5') >>> m.update(b'123456') >>> m.hexdigest() '202cb962ac59075b964b07152d234b70'
可以使用hashlib.algorithms_guaranteed或者hashlib.algorithms_available這兩個內置屬性查看hashlib支持哪些加密算法。
hashlib.algorithms_guaranteed是在所有平臺上,保證被hashlib模塊支持的hash算法名稱的集合;
hashlib.algorithms_available是在當前運行的python編譯器可用的hash算法名稱的集合,由于OpenSSL的原因,在這當中可能會出現重復的hash算法名稱。
hashlib.algorithms_guaranteed是hashlib.algorithms_available的子集。
看下面輸出:
>>> hashlib.algorithms_guaranteed {'sha3_384', 'md5', 'blake2s', 'sha3_512', 'blake2b', 'shake_128', 'sha384', 'sha3_256', 'sha1', 'shake_256', 'sha3_224', 'sha512', 'sha256', 'sha224'} >>> hashlib.algorithms_available {'whirlpool', 'ripemd160', 'dsaEncryption', 'sha1', 'SHA224', 'sha512', 'sha256', 'SHA512', 'blake2s', 'blake2b', 'SHA256', 'sha384', 'sha3_256', 'SHA384', 'sha', 'sha224', 'RIPEMD160', 'shake_128', 'sha3_512', 'SHA', 'MD5', 'shake_256', 'DSA', 'sha3_384', 'DSA-SHA', 'ecdsa-with-SHA1', 'md5', 'SHA1', 'dsaWithSHA', 'md4', 'MD4', 'sha3_224'}
2. hash.update(arg)
傳入arg對象來更新hash的對象。必須注意的是,該方法只接受byte類型,否則會報錯。這就是要在參數前添加b 來轉換類型的原因:
>>> m = hashlib.md5() >>> m.update('123456') TypeError: Unicode-objects must be encoded before hashing
同時要注意,重復調用update(arg)方法,是會將傳入的arg參數進行拼接,而不是覆蓋。必須注意這一點,因為你在不熟悉update()原理的時候,你很可能就會被它坑了。
也就是說,m.update(a); m.update(b) 等價于m.update(a+b),看下面例子:
>>> m = hashlib.md5() >>> m.update(b'123') >>> m.hexdigest() '202cb962ac59075b964b07152d234b70' >>> m.update(b'456') >>> m.hexdigest() 'e10adc3949ba59abbe56e057f20f883e' >>> hashlib.md5(b'123456').hexdigest() 'e10adc3949ba59abbe56e057f20f883e'
3. hash.hexdigest()
都知道,在英語中hex有十六進制的意思,因此該方法是將hash中的數據轉換成數據,其中只包含十六進制的數字。另外還有hash.digest()方法。
以上這篇python3中的md5加密實例就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。