首頁 >後端開發 >Python教學 >hashlib模組之加密的介紹

hashlib模組之加密的介紹

PHP中文网
PHP中文网原創
2017-06-21 10:17:481617瀏覽

  用於加密相關的操作,3.x裡取代了md5模組和sha模組,主要提供 SHA1, SHA224, SHA256, SHA384, SHA512 ,MD5 演算法

import hashlib

m = hashlib.md5()
m.update(b"hello")
print(m.hexdigest())
m.update(b"It's me")
print(m.hexdigest())
m.update(b"It's been a long time since we spoken.")
print(m.hexdigest())

m2 = hashlib.md5()
m2.update(b"helloIt's me")
print(m2.hexdigest())

# 输出
5d41402abc4b2a76b9719d911017c592
64f69d95135bc13d4827f871b37f780f
0c9a83e10aa2f9e9629be61146db9cc2
64f69d95135bc13d4827f871b37f780f

#第二个和第四个 md5值是相同的,所以第二个加密的是 helloIt'sme

  #  #  #  #  #  #」 ##print(m.digest()) #2進位格式hash

  print#(len(m.hexdigest())) ##16進位格式hash
 
#
# ######## sha1 ########
 
hash = hashlib.sha1()
hash.update('admin')
print(hash.hexdigest())
 
# ######## sha256 ########
 
hash = hashlib.sha256()
hash.update('admin')
print(hash.hexdigest())
 
 
# ######## sha384 ########
 
hash = hashlib.sha384()
hash.update('admin')
print(hash.hexdigest())
 
# ######## sha512 ########
 
hash = hashlib.sha512()
hash.update('admin')
print(hash.hexdigest())
python 還有一個hmac 模組,它內部對我們創建key 和內容再進行處理然後再加密

散列訊息鑑別碼,簡稱HMAC,是一種基於訊息鑑別碼MAC (Message Authentication Code)的鑑別機制。使用HMAC時,訊息通訊的雙方,透過驗證訊息中加入的鑑別金鑰K來鑑別訊息的真偽;

一般用於網路通訊中訊息加密,前提是雙方先要約定好key,就像接頭暗號一樣,然後訊息發送把用key把訊息加密,接收方用key + 訊息明文再加密,拿加密後的值跟發送者的相對比是否相等,這樣就能驗證訊息的真實性,及發送者的合法性了。

import hmac

h = hmac.new("天王盖地虎".encode(encoding="utf-8"), "你是小松鼠".encode(encoding="utf-8"))
print(h.digest())
print(h.hexdigest())

#输出
b'fx\xad\xdd\x9e\xd6\xddcQN\x82c\xcd\xd9\x80-'
6678addd9ed6dd63514e8263cdd9802d
#

以上是hashlib模組之加密的介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn