摘要:使用算法名稱構造函數較使用更快所有平臺的模塊都支持的算法的名稱集合。的結果集總是結果集的子集對象的字節長度對象的內部塊大小對象的名稱傳遞類字節參數通常是更新對象。表示的哈希摘要算法的名稱,比如或。表示迭代次數,基于算法以及機器計算能力設置。
hashlib模塊實現了多種安全哈希和信息摘要算法的通用接口,包括FIPS中定義的SHA1, SHA224, SHA256, SHA384, SHA512以及RFC 1321中定義的MD5
注意點:
1. adler32及crc32哈希由zlib模塊提供
2. 某些算法已知存在哈希碰撞弱點
每個hash算法都有一個同名的構造函數,并返回擁有相同接口的hash對象
sha1(), sha224(), sha256(), sha384(), sha512(), blake2b()以及blake2s()這些構造函數在hashlib模塊中總是可用。md5()通常也可用,但在某些罕見的python版本(“FIPS compliant” build of Python)中例外。取決于所用平臺上python使用的OpenSSL,hashlib也支持某些額外的算法,在大多數平臺上,sha3_224(), sha3_256(), sha3_384(), sha3_512(), shake_128(), shake_256()都是可用的。
>>> import hashlib >>> m = hashlib.sha256() >>> m.update(b"Nobody inspects") >>> m.update(b" the spammish repetition") >>> m.digest() b"x03x1exdd}Aex15x93xc5xfex00oxa5u+7xfdxdfxf7xbcNx84:xa6xafx0cx95x0fKx94x06"
或者更精簡的方式:
>>> hashlib.sha256(b"Nobody inspects the spammish repetition").digest() b"x03x1exdd}Aex15x93xc5xfex00oxa5u+7xfdxdfxf7xbcNx84:xa6xafx0cx95x0fKx94x06"hashlib.new(name[, data])
通用構造函數,name參數表示要使用的hash算法的名稱,可以是上述列出的所有hash算法以及OpenSSL庫支持的其他算法。使用算法名稱構造函數較使用new()更快
>>> h = hashlib.new("sha256", b"Nobody inspects the spammish repetition") >>> h.digest() b"x03x1exdd}Aex15x93xc5xfex00oxa5u+7xfdxdfxf7xbcNx84:xa6xafx0cx95x0fKx94x06"hashlib.algorithms_guaranteed
所有平臺的hashlib模塊都支持的hash算法的名稱集合。md5也在此集合中(Note that ‘md5’ is in this list despite some upstream vendors offering an odd “FIPS compliant” Python build that excludes it.)。
hashlib.algorithms_available當前運行的python解釋器支持的hash算法的名稱集合,在new()構造函數中使用都能被正確識別。同一算法可能以不同名稱出現多次。
hashlib.algorithms_guaranteed的結果集總是hashlib.algorithms_available結果集的子集
hash對象的字節長度
hash.block_sizehash對象的內部塊大小
hash.namehash對象的名稱
hash.update(data)傳遞類字節參數(通常是bytes)更新hash對象。重復調用update()等同于單次的拼接調用:m.update(a); m.update(b)等同m.update(a+b)
從python3.1開始,為了更好的多線程性能,使用OpenSSL支持的hash算法且處理數據量大于2047個字節的update(或創建)操作發生時,將釋放python全局解釋器鎖允許其他線程運行
hash.digest()截止此方法調用時,update()已接收的數據的摘要,是一個可包含0到255之間所有字節的字節對象
hash.hexdigest()類似于digest(),不過是以雙倍長度的只包含十六進制數字的字符串對象返回摘要值。
hash.copy()返回hash對象的克隆
SHAKE算法的可變長度摘要The shake_128() and shake_256() algorithms provide variable length digests with length_in_bits//2 up to 128 or 256 bits of security
shake.digest(length)同hash.digest()
shake.hexdigest(length)同hash.hexdigest()
密鑰導出密鑰導出和擴展算法是為安全密碼散列設計的。類似sha1(password)這種簡單算法不能有效抵御暴力破解,一個好的密碼散列函數必須是可調節的,耗時的,并包含鹽
hashlib.pbkdf2_hmac(hash_name, password, salt, iterations, dklen=None)pbkdf2_hmac()提供了使用PKCS#5填充的pbkdf2算法,使用HMAC作為偽隨機函數。
hash_name表示HMAC的哈希摘要算法的名稱,比如"sha1"或"sha256"。
password和salt是類字節對象,password長度應該限制在一個合理范圍之間,salt長度應該在16個字節以上且來源恰當。
iterations表示迭代次數,基于hash算法以及機器計算能力設置。截止2013年,sha256算法建議最少進行10萬次迭代
dklen表示導出密鑰的長度。默認值為None,使用hash_name算法計算的hash對象的digest_size屬性長度
>>> import hashlib, binascii >>> dk = hashlib.pbkdf2_hmac("sha256", b"password", b"salt", 100000) >>> binascii.hexlify(dk) b"0394a2ede332c9a13eb82e9b24631604c31df978b4e2f0fbd2c549944f9d79a5"
Note: A fast implementation of pbkdf2_hmac is available with OpenSSL. The Python implementation uses an inline version of hmac. It is about three times slower and doesn’t release the GIL.
hashlib.scrypt(password, *, salt, n, r, p, maxmem=0, dklen=64)The function provides scrypt password-based key derivation function as defined in RFC 7914.
password和salt是類字節對象,password長度應該限制在一個合理范圍之間,salt長度應該在16個字節以上且來源恰當。
n is the CPU/Memory cost factor, r the block size, p parallelization factor and maxmem limits memory (OpenSSL 1.1.0 defaults to 32 MiB). dklen is the length of the derived key.
BLAKE2待補充...實在是編不下去了,對加密算法相關的知識太缺乏了
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/42573.html
摘要:唯一要求使用中的進行加密請輸入你的賬號請輸入你的密碼加鹽操作加密加密輸入正確輸入錯誤請輸入你要注冊的名字請輸入你要注冊的密碼加密加密請輸入你要執行的操作注冊登錄退出問題是 ...
摘要:上一篇文章模塊分析第節模塊下一篇文章模塊分析第節模塊模塊是用來對字符串進行加密的模塊,明文與密文是一一對應不變的關系用于注冊登錄時用戶名密碼等加密使用。一函數分析共有種加密算法,分別得到不同的加密密文。 上一篇文章:Python模塊分析:第1節-random模塊下一篇文章:Python模塊分析:第3節-typing模塊 hashlib模塊是用來對字符串進行hash加密的模塊,明文與密...
摘要:的作用是讓大容量信息在用數字簽名軟件簽署私人密鑰前被壓縮成一種保密的格式就是把一個任意長度的字節串變換成一定長的十六進制數字串。獲取由位隨機大小寫字母數字組成的值每次從中隨機取一位獲取原始密碼的值原始密碼隨機生成位加密后的密碼 MD5是什么 下面的概念是百度百科的: Message Digest Algorithm MD5(中文名為消息摘要算法第五版)為計算機安全領域廣泛使用的一種散列...
摘要:可能沒有用戶輸出的消息創建一個,用于寫入日志文件再創建一個,用于輸出到控制臺對象可以添加多個和對象序列化模塊什么叫序列化將原本的字典列表等內容轉換成一個字符串的過程就叫做序列化。 hashlib模塊 1.Python的hashlib提供了常見的摘要算法,如MD5,SHA1等等。什么是摘要算法呢?摘要算法又稱哈希算法、散列算法。它通過一個函數,把任意長度的數據轉換為一個長度固定的數據串(...
摘要:例如等價于到結束,但不包括。例如返回沒有每次跳躍的間距,默認為。 異常處理 單個異常處理: try: print(num) except NameError: print(沒有定義變量) except FileNotFoundError: print(找不到文件路徑) print(1) 多個異常處理: try: print(num) # 1...
閱讀 1171·2021-10-15 09:39
閱讀 3070·2021-09-10 10:50
閱讀 3464·2019-08-30 15:53
閱讀 1890·2019-08-30 15:52
閱讀 2578·2019-08-29 15:31
閱讀 1985·2019-08-26 13:43
閱讀 2606·2019-08-26 13:37
閱讀 1449·2019-08-23 18:31