本篇文章給大家分享的是有關(guān)怎么在Python中使用內(nèi)置的加密模塊,小編覺(jué)得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說(shuō),跟著小編一起來(lái)看看吧。
創(chuàng)新互聯(lián)建站專業(yè)為企業(yè)提供東興網(wǎng)站建設(shè)、東興做網(wǎng)站、東興網(wǎng)站設(shè)計(jì)、東興網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁(yè)設(shè)計(jì)與制作、東興企業(yè)網(wǎng)站模板建站服務(wù),10多年東興做網(wǎng)站經(jīng)驗(yàn),不只是建網(wǎng)站,更提供有價(jià)值的思路和整體網(wǎng)絡(luò)服務(wù)。數(shù)據(jù)加密:
對(duì)稱加密:數(shù)據(jù)加密和解密使用相同的密鑰,主要解決數(shù)據(jù)的機(jī)密性(DES,AES)
非對(duì)稱加密(公匙加密):數(shù)據(jù)加密和解密使用的不同密鑰,主要用于身份的驗(yàn)證(DSA,RSA)
單向加密:只能加密不能解密,主要用于解決數(shù)據(jù)的完整性(MD5,SHA系列算法)
Python內(nèi)置加密模塊:
hashlib | 主要提供了一些常見(jiàn)的單向加密算法(如MD5,SHA等) |
hmac | 單向加密算法,支持設(shè)置一個(gè)額外的密匙(salt)來(lái)提高安全性 |
secrets | Python3.6新增用于獲取安全隨機(jī)數(shù) |
1.hashlib 模塊
其中主要包含了MD5和SHA模塊的功能,還提供了如MD5,SHA1,SHA224,SHA256,SHA384和SHA512(輸出長(zhǎng)度不同)等算法的函數(shù)實(shí)現(xiàn)
hashlib模塊包含的函數(shù)與屬性:
hashlib.new(name[,data]) | 用于構(gòu)造指定的哈希算法所對(duì)應(yīng)的哈希對(duì)象,name可用于指定哈希算法的名稱,如‘MD5',‘sha1',不分大小寫(xiě),data為一個(gè)可選參數(shù) |
hashlib.algorithms_guaranteed | 它的值是一個(gè)該模塊在所有平臺(tái)都會(huì)支持的哈希算法的名稱集合:set(['sha1','sha224','sha384','sha256','sha512','md5']) |
hashlib.algorithms_available | 它的值是一個(gè)當(dāng)前運(yùn)行的Python解釋器中可用的哈希算法的名稱集合,algorithms_guaranteed將永遠(yuǎn)是它的子集 |
hash對(duì)象包含的方法與屬性:
hash.update() | 更新哈希對(duì)象所要計(jì)算的數(shù)據(jù),多次調(diào)用為累加效果,如m.update(a);m.update(b)等價(jià)于m.update(a+b) |
hash.digest() | 以二進(jìn)制格式返回傳遞給update()函數(shù)的所有數(shù)據(jù)的摘要信息(字符串) |
hash.hexdigest() | 以十六進(jìn)制格式返回傳遞給update()函數(shù)的所有數(shù)據(jù)的摘要信息(字符串) |
hash.copy() | 可用來(lái)有效計(jì)算共享一個(gè)初始子串的數(shù)據(jù)的摘要信息 |
hash.digest_size | hash結(jié)果的字節(jié)大小,即hash.digest()方法返回結(jié)果的字符串長(zhǎng)度,MD5:16,sha1:20,sha224:28 |
hash.block_size | hash算法內(nèi)部塊的字節(jié)大小 |
hash.name | 當(dāng)前hash對(duì)象對(duì)應(yīng)的哈希算法的標(biāo)準(zhǔn)名稱(小寫(xiě)形式),可以直接傳遞hashlib.new()函數(shù)來(lái)創(chuàng)建另外一個(gè)同類型的哈希對(duì)象 |
實(shí)例:
important
import hashlib hash = hashlib.md5() hash.update(b'Hello, ') hash.update(b'World!') ret1 = hash.digest() # 以二進(jìn)制格式返回?cái)?shù)據(jù)的加密信息 print(type(ret1), len(ret1), ret1) ret2 = hash.hexdigest() # 以十六進(jìn)制返回加密的數(shù)據(jù)值 print(type(ret2), len(ret2), ret2)
result
16 b'e\xa8\xe2}\x88y(81\xb6d\xbd\x8b\x7f\n\xd4' 32 65a8e27d8879283831b664bd8b7f0ad4
注: 只要輸入的內(nèi)容和加密模式相同,則輸出的密匙就相同
2.hmac模塊
實(shí)現(xiàn)了HAMC算法,與hashlib提供的API基本一致
hamc模塊提供的函數(shù):
hamc.new(key,msg=None,digestmod=None) | 用于創(chuàng)建一個(gè)hmac對(duì)象,key為密鑰,msg為初始數(shù)據(jù),digestmod為所使用的哈希算法,默認(rèn)為hashlib.md5 |
hmac.compare_digest(a,b) | 比較兩個(gè)hmac對(duì)象,返回的是a==b的值 |
hamc對(duì)象中提供的方法與屬性 與 hash對(duì)象中一致
實(shí)例:
improtant
import hmac h2 = hmac.new(b'yeah', b'a', digestmod=hashlib.sha224) # digestmod 默認(rèn)為MD5 h2.update(b'hello') ret1 = h2.digest() # 二進(jìn)制 ret2 = h2.hexdigest() # 十六進(jìn)制 print(type(ret1), ret1) print(type(ret2), ret2) h3 = hmac.new(b'yeah', b'name') ret3 = h3.hexdigest() c = hmac.compare_digest(ret2, ret3) # 比較同類型進(jìn)制的值 print(c)
result
b'&\x9a\xd0{\x15WTE9@\xd9\xe3z\xfb+\\o\xc5\x88\x7f\x1c\xa4Q\xaf\x0c\n\xa8E' 269ad07b155754453940d9e37afb2b5c6fc5887f1ca451af0c0aa845 False
3.secrets模塊
生成用于管理密碼、賬戶驗(yàn)證信息、安全令牌和相關(guān)秘密信息等數(shù)據(jù)的密碼強(qiáng)隨機(jī)數(shù)
secrets模塊的兩種操作:
生成安全隨機(jī)數(shù)
生成一個(gè)篤定長(zhǎng)度的隨機(jī)字符串(可用作令牌和安全URL)
secrets模塊提供的函數(shù):
secrets.choice(sequence) | 從指定的非空序列中隨機(jī)選擇一個(gè)元素并返回 |
secrets.randbelow(n) | 從半開(kāi)區(qū)間[0,n]內(nèi)隨機(jī)返回一個(gè)整數(shù) |
secrets.randbits(k) | 返回一個(gè)帶有k個(gè)隨機(jī)位的整數(shù) |
secrets.token_bytes(nbytes=None) | 返回一個(gè)包含nbytes個(gè)字節(jié)的隨機(jī)字符串 |
secrets.token_hex(nbytes=None) | 返回一個(gè)包含nbytes字節(jié)的16進(jìn)制格式的隨機(jī)文本字符串,可以用來(lái)生成一個(gè)隨機(jī)密碼 |
secrets.token_urlsafe([nbytes]) | 返回一個(gè)包含nbytes個(gè)字節(jié)的隨機(jī)安全URL文本字符串,可以在提供重置密碼的應(yīng)用中用來(lái)生成一個(gè)臨時(shí)的隨機(jī)令牌 |
secrets.compare_digest(a,b) | 比較a,b字符串是否相等,若相等,返回True |
實(shí)例:
important
import secrets a = range(0, 99) s = secrets.choice(a) b = secrets.randbelow(77) print(s) print(b) print(secrets.randbits(k=6)) print(secrets.token_bytes(nbytes=2)) print(secrets.token_hex(nbytes=2)) print(secrets.token_urlsafe(2)) print(secrets.compare_digest('a', 'b')) # 比較'字符串'
result
32 b'op' b248 LNI False
以上就是怎么在Python中使用內(nèi)置的加密模塊,小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見(jiàn)到或用到的。希望你能通過(guò)這篇文章學(xué)到更多知識(shí)。更多詳情敬請(qǐng)關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計(jì)公司行業(yè)資訊頻道。
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。