国产探花免费观看_亚洲丰满少妇自慰呻吟_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教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 江陵县| 穆棱市| 沁阳市| 高阳县| 八宿县| 福州市| 高碑店市| 陆良县| 美姑县| 炎陵县| 景宁| 怀宁县| 长丰县| 湟源县| 米泉市| 湘阴县| 长寿区| 志丹县| 呼伦贝尔市| 嘉鱼县| 同江市| 遵义县| 曲沃县| 阳谷县| 彰化县| 蒙山县| 墨玉县| 吉隆县| 阿鲁科尔沁旗| 壤塘县| 镇安县| 宁化县| 岚皋县| 电白县| 五指山市| 贵州省| 左云县| 开远市| 句容市| 阳高县| 偏关县|