溫馨提示×

溫馨提示×

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

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

Python中有哪些常見的加密操作

發(fā)布時(shí)間:2021-03-12 17:04:36 來源:億速云 閱讀:387 作者:Leah 欄目:開發(fā)技術(shù)

這篇文章給大家介紹Python中有哪些常見的加密操作,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

hashlib加密

import hashlib
 
# 有很多種加密方式,md5,sha1等等
h = hashlib.md5()
# 提交加密的內(nèi)容,bytes形式
h.update(b"satori")
# 二進(jìn)制形式
print(h.digest())
'''
b'\x13\xd54\x0f:\xdf\x8e[\xe0\x83\xdd\xc6\xca\xd2G\xb8'
'''
# 十六進(jìn)制形式
print(h.hexdigest())
'''
13d5340f3adf8e5be083ddc6cad247b8
'''
import hashlib
 
# 相對的,還有簡便的操作
# 直接指定要加密的字符串
h2 = hashlib.md5(b"satori")
print(h2.hexdigest())
'''
13d5340f3adf8e5be083ddc6cad247b8
'''
 
h3 = hashlib.md5()
h3.update(b"satori")
print(h3.hexdigest())
'''
13d5340f3adf8e5be083ddc6cad247b8
'''
# 兩者結(jié)果是一樣的

hmac加密

import hmac
import hashlib
 
# key:密鑰
# msg:內(nèi)容
# digestmod:加密的模式,默認(rèn)是md5
h2 = hmac.new(key=b"satori", msg=b"satori", digestmod=hashlib.md5)
print(h2.hexdigest())
'''
3cba321fbb4e02c5b7e9fb7ef82bb47b
'''
 
# 也可以通過update添加內(nèi)容,是添加,不是覆蓋
h3 = hmac.new(key=b"satori")
h3.update(b"satori")
print(h3.hexdigest())
'''
3cba321fbb4e02c5b7e9fb7ef82bb47b
'''

secrets

import secrets
 
# secrets貌似是python3.6里新增的模塊,先來看看api
# secrets.choice(iterable),從可迭代對象里隨機(jī)選擇一個(gè)元素并返回
# secrets.randbelow(n),從[0,n)中隨機(jī)選擇一個(gè)數(shù)并返回
# secrets.randbits(k),返回帶有k個(gè)隨機(jī)位的整數(shù)
# secrets.token_bytes(nbytes=None),返回一個(gè)包含n個(gè)bytes的隨機(jī)字符串
# secrets.token_hex(nbytes=None),返回一個(gè)包含n個(gè)bytes的16進(jìn)制隨機(jī)文本字符串,每個(gè)字節(jié)轉(zhuǎn)換成兩個(gè)16進(jìn)制數(shù)字,一般用來生成隨即密碼
# secrets.token_urlsafe(nbytes=None),返回一個(gè)包含n個(gè)bytes的隨即url字符串,可以用來生成一個(gè)臨時(shí)的隨機(jī)令牌
# secrets.compare_digest(a, b),比較兩個(gè)字符串是否相等
 
print(secrets.choice("古明地盆"))  # 古
print(secrets.choice(["satori", "mashiro", "nagisa"]))  # nagisa
# 和random.choice()是類似的
 
print(secrets.randbelow(8))  # 6
# 和random.randint()類似,但是secrets.randbelow()只能默認(rèn)從零開始,且不包含右端點(diǎn)
 
print(secrets.randbits(7))  # 96
 
print(secrets.token_bytes())  # b'\x87\x98\x1c\x80TO\xcf\x82\xc9\xf1\xd6\xf6f\xd7\xd7\xae\xea.\xfd0y\xd6\xaf\xfbe\xb4v\x8b@\xc8t\xe6'
print(secrets.token_bytes(nbytes=20))  # b'\xa5:(\xf2\xcb\xb2\xd8\xbce\xacn\x8c\x95\x05:\x07e#\xa7M'
 
print(secrets.token_hex())  # 0904e492deaab1270f11671d687f3bb2c7ead5283bfe55a3b51e560101c38828
print(secrets.token_hex(20))  # 851801ed1367bc946b1f28812a83a7e84d91908e
 
print(secrets.token_urlsafe())  # sGGhrL8VLECMYalQ5DHMDm0yugoVsr2M-SvN4z2Qk8k
print(secrets.token_urlsafe(nbytes=20))  # PIvP0VoRxvfignT1MH_p2vNog9U

base64

import base64
 
s = bytes("古明地盆", encoding="utf-8")
 
en_data1 = base64.b64encode(s)
print(en_data1)  # b'5Y+k5piO5Zyw55uG'
de_data1 = base64.b64decode(en_data1)
print(str(de_data1, encoding="utf-8"))  # 古明地盆
 
# 可以看出來,是為了考慮url安全的一種加密方式
# 與普通的b64encode不同的是,會將一些字符進(jìn)行一個(gè)替換
en_data2 = base64.urlsafe_b64encode(s)
print(en_data2)  # b'5Y-k5piO5Zyw55uG'
de_data2 = base64.urlsafe_b64decode(en_data2)
print(str(de_data2, encoding="utf-8"))  # 古明地盆

cryptography

from cryptography.fernet import Fernet
 
# 生成秘鑰cipher_key
cipher_key = Fernet.generate_key()
 
# 傳入秘鑰實(shí)例化一個(gè)類
cipher = Fernet(cipher_key)
 
text = '古明地覺'.encode("utf-8")
 
#進(jìn)行加密
encrypted_text = cipher.encrypt(text)
print(type(encrypted_text))  # <class 'bytes'>
 
#進(jìn)行解密
decrypted_text = cipher.decrypt(encrypted_text)
print(decrypted_text.decode("utf-8"))  # 古明地覺

關(guān)于Python中有哪些常見的加密操作就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI