国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

Python3 加密(hashlib和hmac)模塊的實現

2020-01-04 16:16:13
字體:
來源:轉載
供稿:網友

以下代碼以python/287879.html">Python3.6.1為例

  1. hashlib : 不可逆加密
  2. hmac : 不可逆鍵值對方式加密

hashlib模塊簡介:

hashlib模塊為不同的安全哈希/安全散列(Secure Hash Algorithm)和 信息摘要算法(Message Digest Algorithm)實現了一個公共的、通用的接口,也可以說是一個統一的入口。因為hashlib模塊不僅僅是整合了md5和sha模塊的功能,還提供了對更多中算法的函數實現,如:MD5,SHA1,SHA224,SHA256,SHA384和SHA512。

hashlib模塊使用步驟:

1)獲取一個哈希算法對應的哈希對象(比如名稱為hash): 可以通過 hashlib.new(哈希算法名稱, 初始出入信息)函數,來獲取這個哈希對象,如hashlib.new('MD5', 'Hello'),hashlib.new('SHA1', 'Hello')等;也可以通過hashlib.哈希算法名稱()來獲取這個哈希對象,如hashlib.md5(), hashlib.sha1()等。

2)設置/追加輸入信息: 調用已得到哈希對象的update(輸入信息)方法可以設置或追加輸入信息,多次調用該方法,等價于把每次傳遞的參數憑借后進行作為一個參數墊底給update()方法。也就是說,多次調用是累加,而不是覆蓋。

3)獲取輸入信息對應的摘要: 調用已得到的哈希對象的digest()方法或hexdigest()方法即可得到傳遞給update()方法的字符串參數的摘要信息。digest()方法返回的摘要信息是一個二進制格式的字符串,其中可能包含非ASCII字符,包括NUL字節,該字符串長度可以通過哈希對象的digest_size屬性獲?。欢鴋exdigest()方法返回的摘要信息是一個16進制格式的字符串,該字符串中只包含16進制的數字,且長度是digest()返回結果長度的2倍,這可用郵件的安全交互或其它非二進制的環境中。

#!/usr/bin/env python# coding=utf-8__author__ = 'Luzhuo'__date__ = '2017/5/19'# hash_demo.py Hash加密相關(安全哈希)# 支持: MD5, SHA1 SHA224 SHA256 SHA384 SHA512import hashlibdef 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()) # 二進制hash  print(m.hexdigest()) # 十六進制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]) // 創建hashlib(非首選), name=算法名, data:數據  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:數據, salt:鹽, iterations:循環次數, dklen:密鑰長度  hash_bytes = hashlib.pbkdf2_hmac('sha256', b'luzhuo.me', b'80', 100000)  # hash對象  num = hash.digest_size # hash結果的大小  num = hash.block_size # hash算法的內部塊的大小  strs = hash.name # hash名稱, 可傳給new()使用  hash.update(b"data") # 字節緩沖區 hash.update(a) hash.update(b) == hash.update(a+b)  hash_bytes = hash.digest() # 字節hash  hash_str = hash.hexdigest() # 16進制字符串hash  hash = hash.copy() # 拷貝hash對象副本 if __name__ == "__main__":  hash_demo()  # hash_func()

hashmac模塊簡介:

前面說過,HMAC算法也是一種一種單項加密算法,并且它是基于上面各種哈希算法/散列算法的,只是它可以在運算過程中使用一個密鑰來增增強安全性。hmac模塊實現了HAMC算法,提供了相應的函數和方法,且與hashlib提供的api基本一致。

hmac模塊使用步驟:

hmac模塊模塊的使用步驟與hashlib模塊的使用步驟基本一致,只是在第1步獲取hmac對象時,只能使用hmac.new()函數,因為hmac模塊沒有提供與具體哈希算法對應的函數來獲取hmac對象。

#!/usr/bin/env python# coding=utf-8__author__ = 'Luzhuo'__date__ = '2017/5/19'# hmac_demo.py HMAC算法# 與hashlib不同之處在于多了keyimport hmacdef 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():  # 創建key和內容,再都進行加密  # hmac.new(key, msg=None, digestmod=None) // 創建新的hmac對象, key:鍵, msg:update(msg), digestmod:hash名稱(同hashlib.new())(默認md5)  hc = hmac.new(b"key")  # hmac對象  hc.update(b"msg") # 字節緩沖區 hc.update(a) hc.update(b) == hc.update(a+b)  hash_bytes = hc.digest() # 字節hash  hash_str = hc.hexdigest() # 16進制hash字符串  hc = hc.copy() # 拷貝hmac副本  num = hc.digest_size # hash大小  num = hc.block_size # hash算法內部塊大小  strs = hc.name # hash名稱  # hmac.compare_digest(a, b) // 比較兩個hash密鑰是否相同, 參數可為: 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()

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。


注:相關教程知識閱讀請移步到python教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 汉源县| 抚顺市| 龙口市| 山丹县| 濮阳县| 金寨县| 裕民县| 苏尼特右旗| 黄龙县| 沙河市| 来安县| 登封市| 法库县| 阿克陶县| 崇阳县| 龙泉市| 宽城| 余干县| 奈曼旗| 贺州市| 怀来县| 龙口市| 信丰县| 新兴县| 武清区| 伊春市| 台山市| 平远县| 新乡县| 平阳县| 六安市| 左权县| 赤城县| 邻水| 桑植县| 含山县| 武宣县| 贵港市| 朝阳市| 黔江区| 德令哈市|