Python3 加密(hashlib和hmac)模塊的實(shí)現(xiàn)
以下代碼以Python3.6.1為例
- hashlib : 不可逆加密
- hmac : 不可逆鍵值對方式加密
hashlib模塊簡介:
hashlib模塊為不同的安全哈希/安全散列(Secure Hash Algorithm)和 信息摘要算法(Message Digest Algorithm)實(shí)現(xiàn)了一個公共的、通用的接口,也可以說是一個統(tǒng)一的入口。因?yàn)閔ashlib模塊不僅僅是整合了md5和sha模塊的功能,還提供了對更多中算法的函數(shù)實(shí)現(xiàn),如:MD5,SHA1,SHA224,SHA256,SHA384和SHA512。
hashlib模塊使用步驟:
1)獲取一個哈希算法對應(yīng)的哈希對象(比如名稱為hash): 可以通過 hashlib.new(哈希算法名稱, 初始出入信息)函數(shù),來獲取這個哈希對象,如hashlib.new('MD5', 'Hello'),hashlib.new('SHA1', 'Hello')等;也可以通過hashlib.哈希算法名稱()來獲取這個哈希對象,如hashlib.md5(), hashlib.sha1()等。
2)設(shè)置/追加輸入信息: 調(diào)用已得到哈希對象的update(輸入信息)方法可以設(shè)置或追加輸入信息,多次調(diào)用該方法,等價(jià)于把每次傳遞的參數(shù)憑借后進(jìn)行作為一個參數(shù)墊底給update()方法。也就是說,多次調(diào)用是累加,而不是覆蓋。
3)獲取輸入信息對應(yīng)的摘要: 調(diào)用已得到的哈希對象的digest()方法或hexdigest()方法即可得到傳遞給update()方法的字符串參數(shù)的摘要信息。digest()方法返回的摘要信息是一個二進(jìn)制格式的字符串,其中可能包含非ASCII字符,包括NUL字節(jié),該字符串長度可以通過哈希對象的digest_size屬性獲??;而hexdigest()方法返回的摘要信息是一個16進(jìn)制格式的字符串,該字符串中只包含16進(jìn)制的數(shù)字,且長度是digest()返回結(jié)果長度的2倍,這可用郵件的安全交互或其它非二進(jìn)制的環(huán)境中。
#!/usr/bin/env python # coding=utf-8 __author__ = 'Luzhuo' __date__ = '2017/5/19' # hash_demo.py Hash加密相關(guān)(安全哈希) # 支持: MD5, SHA1 SHA224 SHA256 SHA384 SHA512 import hashlib def hash_demo(): m = hashlib.md5() m.update(b"hello") m.update(b"world!") # = hello + world! hash_hex = hashlib.sha3_512(b"luzhuo.me").hexdigest() print(m.digest_size) print(m.digest()) # 二進(jìn)制hash print(m.hexdigest()) # 十六進(jìn)制hash print(hash_hex) # 加鹽加密 hash_bytes = hashlib.pbkdf2_hmac('sha256', b'luzhuo.me', b'80', 100000) print(hash_bytes) def hash_func(): # hashlib.new(name[, data]) // 創(chuàng)建hashlib(非首選), name=算法名, data:數(shù)據(jù) hash = hashlib.new('ripemd160', b'luzhuo.me') # 常量 dics = hashlib.algorithms_guaranteed # 所有平臺支持的hash算法的名稱 dics = hashlib.algorithms_available # 在Python解析器中可用的hash算法的名稱, 傳遞給new()時, 可識別 # hashlib.pbkdf2_hmac(hash_name, password, salt, iterations, dklen=None) // 加鹽加密 hash_name:hash名稱, password:數(shù)據(jù), salt:鹽, iterations:循環(huán)次數(shù), dklen:密鑰長度 hash_bytes = hashlib.pbkdf2_hmac('sha256', b'luzhuo.me', b'80', 100000) # hash對象 num = hash.digest_size # hash結(jié)果的大小 num = hash.block_size # hash算法的內(nèi)部塊的大小 strs = hash.name # hash名稱, 可傳給new()使用 hash.update(b"data") # 字節(jié)緩沖區(qū) hash.update(a) hash.update(b) == hash.update(a+b) hash_bytes = hash.digest() # 字節(jié)hash hash_str = hash.hexdigest() # 16進(jìn)制字符串hash hash = hash.copy() # 拷貝hash對象副本 if __name__ == "__main__": hash_demo() # hash_func()
hashmac模塊簡介:
前面說過,HMAC算法也是一種一種單項(xiàng)加密算法,并且它是基于上面各種哈希算法/散列算法的,只是它可以在運(yùn)算過程中使用一個密鑰來增增強(qiáng)安全性。hmac模塊實(shí)現(xiàn)了HAMC算法,提供了相應(yīng)的函數(shù)和方法,且與hashlib提供的api基本一致。
hmac模塊使用步驟:
hmac模塊模塊的使用步驟與hashlib模塊的使用步驟基本一致,只是在第1步獲取hmac對象時,只能使用hmac.new()函數(shù),因?yàn)閔mac模塊沒有提供與具體哈希算法對應(yīng)的函數(shù)來獲取hmac對象。
#!/usr/bin/env python # coding=utf-8 __author__ = 'Luzhuo' __date__ = '2017/5/19' # hmac_demo.py HMAC算法 # 與hashlib不同之處在于多了key import hmac def hmac_demo(): # 加密 h = hmac.new(b"net") h.update(b"luzhuo.me") h_str = h.hexdigest() print(h_str) # 比較密碼 boolean = hmac.compare_digest(h_str, hmac.new(b"net", b"luzhuo.me").hexdigest()) print(boolean) def hmac_func(): # 創(chuàng)建key和內(nèi)容,再都進(jìn)行加密 # hmac.new(key, msg=None, digestmod=None) // 創(chuàng)建新的hmac對象, key:鍵, msg:update(msg), digestmod:hash名稱(同hashlib.new())(默認(rèn)md5) hc = hmac.new(b"key") # hmac對象 hc.update(b"msg") # 字節(jié)緩沖區(qū) hc.update(a) hc.update(b) == hc.update(a+b) hash_bytes = hc.digest() # 字節(jié)hash hash_str = hc.hexdigest() # 16進(jìn)制hash字符串 hc = hc.copy() # 拷貝hmac副本 num = hc.digest_size # hash大小 num = hc.block_size # hash算法內(nèi)部塊大小 strs = hc.name # hash名稱 # hmac.compare_digest(a, b) // 比較兩個hash密鑰是否相同, 參數(shù)可為: str / bytes-like object, (注:建議使用,不建議使用a==b) boolean = hmac.compare_digest(hmac.new(b"net", b"luzhuo.me").digest(), hmac.new(b"net", b"luzhuo.me").digest()) if __name__ == "__main__": hmac_demo() # hmac_func()
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Python在OpenCV里實(shí)現(xiàn)極坐標(biāo)變換功能
這篇文章主要介紹了在OpenCV里實(shí)現(xiàn)極坐標(biāo)變換功能,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-09-09windows系統(tǒng)Tensorflow2.x簡單安裝記錄(圖文)
這篇文章主要介紹了windows系統(tǒng)Tensorflow2.x簡單安裝記錄(圖文),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01python3 requests庫實(shí)現(xiàn)多圖片爬取教程
今天小編就為大家分享一篇python3 requests庫實(shí)現(xiàn)多圖片爬取教程,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-12-12基于django micro搭建網(wǎng)站實(shí)現(xiàn)加水印功能
這篇文章主要介紹了基于django micro搭建網(wǎng)站實(shí)現(xiàn)加水印功能,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-05-05pandas DataFrame 賦值的注意事項(xiàng)說明(index)
這篇文章主要介紹了pandas DataFrame 賦值的注意事項(xiàng)說明(index),具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-04-04