中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何在Python中使用hashlib和hmac加密模塊

發布時間:2021-03-18 16:27:43 來源:億速云 閱讀:152 作者:Leah 欄目:開發技術

這篇文章給大家介紹如何在Python中使用hashlib和hmac加密模塊,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

import hashlib
import time
 
m = hashlib.md5()
 
api_key = ''
api_secret = ''
 
params = {'api_key':api_key, 'time':int(time.time()), 'symbol':'btclcny'}
 
def sign( data , secret ):
  signStr = ""
  keys = data.keys()
  keys = sorted(keys)
  for key in keys:
    signStr = signStr + key
    signStr = signStr + bytes(data[key])
    pass
  signStr += secret
  m.update(signStr)
  return m.hexdigest()
 
print sign( params , api_secret )

實在搞不懂寫的人的意思,里面有字符串與字節碼的相加?反正就是跑不起來,隨便我這個加密模塊也用的少,這次就給自己記錄學習的機會來了。

媽的,這個平臺太垃圾了,接口有問題的,浪費我好長時間,后面還去看了它的PHP代碼,看的腦子發麻,后來仔細研究了傳入 params,里面的接口文檔寫的亂七八糟,浪費時間。一萬頭草泥馬飛過。

切入主題,先講hashlib,后面介紹hmac,有時間下一個章節,把base64還有io,以及pickle,json,shelve,fileinput.

概念:

Python的hashlib提供了常見的摘要算法,如MD5,SHA1等等。

什么是摘要算法呢?摘要算法又稱哈希算法、散列算法。它通過一個函數,把任意長度的數據轉換為一個長度固定的數據串(通常用16進制的字符串表示)。所以看來的hash加密值沒有超過字母f的

后面可以測試每種加密手法的輸出字段長度,也可以知道具體輸出的Byte字節數(一個16進制的數對應4位)。

'''初始化對象'''
h2 = hashlib.md5()
h3 = hashlib.new('md5')
h4 = hashlib.md5()
h2.update(b'123')  # 進行摘要
h3.update('123'.encode())
h4.update(b'1')
h4.update(b'23')
print(h2.hexdigest())  # 取值
print(h3.hexdigest())
print(h4.hexdigest())
202cb962ac59075b964b07152d234b70<br data-filtered="filtered">202cb962ac59075b964b07152d234b70<br data-filtered="filtered">202cb962ac59075b964b07152d234b70

一共有兩種實例化的方法,一般介紹都是第一種。記住,進行進行md5摘要時,對象一定是二進制數據。

update其實可以分開用,只要里面的數據沒有變,分開用書上介紹對大文件操作會更加快。

由于這樣直接加密,沒有添加輔助字符,假如是用戶的密碼設置的很簡單,很容易通過加密后的數據也能反向分析出密碼,所以要添加一些干擾詞匯。

hmac也是干擾加密的另外一種相對看過去比較高級的寫法。

add_word = b'haha'     # 把這個當做加密鹽,
 
hh2 = hashlib.md5()
hh2.update(add_word + b'jiujiu')
print(hh2.hexdigest())
 
hh3 = hashlib.md5()
hh3.update( b'jiujiu' + add_word)
print(hh3.hexdigest())
 
m = hmac.new(add_word) # 這個跟hashlib的寫法有點類似,默認是md5加密
m.update(b'jiujiu')
print(m.hexdigest())
h_md5 = hmac.new(add_word, b'jiujiu').hexdigest() # 這是另外一種方式,直接加密后取值。
h_sha1 = hmac.new(add_word, b'jiujiu', 'sha1').hexdigest()
h_sha224 = hmac.new(add_word, b'jiujiu', 'sha224').hexdigest()
h_sha256 = hmac.new(add_word, b'jiujiu', 'sha256').hexdigest()
h_sha512 = hmac.new(add_word, b'jiujiu', 'sha512').hexdigest()
 
print(h_md5, len(h_md5), sep='======>num')
print(h_sha1, len(h_sha1), sep='======>num')  # 通過輸出可以看出,md5輸出32個16進制數字,一共128位
print(h_sha224, len(h_sha224), sep='======>num')  # sha1輸出40個數字,所以為160位,剩下的sha后面的數字就代表輸出幾位。
print(h_sha256, len(h_sha256), sep='======>num')
print(h_sha512, len(h_sha512), sep='======>num')
3e289c523f955430bce2e47a14d4934b
eb01e09a1fe2bfd95d8f31c8ae544faf
ef84bc9ee2bf91d1789227d82193d7a9
ef84bc9ee2bf91d1789227d82193d7a9======>num32
fbd95ddafdac6352cdf3d9d4e8c6d2421c80e56c======>num40
60d1896d00e73bc67469a58b39ded91c60c162eda0f44306f7d08d58======>num56
b36f8977bba6265612bc338b89c698d17cff7ccfb81b7d7a434f0ad889995e26======>num64
043f51bd410f9d328ca0ab0913ddfde9c2519f639c74447a1516811b8920b125aa6f4d3977c83e038e82c39103ac2a3bbdd5235c9c95fc030a267cdf0d578696======>num128

從整個代碼的操作來看還是比較簡單,至少比我想象的簡單,加密的邏輯我也不懂,我也知道密碼學很高級,就我這小學三年級的數學有空再看吧。

hmac只不過是一種機器加密的手段,但我試過了,無論我把這個加密鹽放加密字節碼的前面或者后面,跟hmac出來的效果不一樣,看來它有自己的拼接加密算法。

至于sha1,sha256,sha512就比較容易記住了,md5是32個16進制數輸出,所以包含bit是128位,sha1是是輸出40個16進制數,所以是160個bit,剩下的比較好理解,后面的數字代表了幾個bit位。

關于如何在Python中使用hashlib和hmac加密模塊就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

稻城县| 肇东市| 达拉特旗| 鹤山市| 汤原县| 虎林市| 西充县| 英德市| 双城市| 临澧县| 尉氏县| 小金县| 司法| 武邑县| 永丰县| 乌海市| 康保县| 肥乡县| 祥云县| 华池县| 云阳县| 普兰店市| 巴塘县| 深州市| 改则县| 天津市| 云浮市| 疏勒县| 宿松县| 盐边县| 星座| 高密市| 建水县| 司法| 南皮县| 灯塔市| 乳山市| 广饶县| 南丹县| 湘潭市| 微山县|