您好,登錄后才能下訂單哦!
這篇文章給大家介紹Python中有哪些常見的加密操作,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
import hashlib # 有很多種加密方式,md5,sha1等等 h = hashlib.md5() # 提交加密的內容,bytes形式 h.update(b"satori") # 二進制形式 print(h.digest()) ''' b'\x13\xd54\x0f:\xdf\x8e[\xe0\x83\xdd\xc6\xca\xd2G\xb8' ''' # 十六進制形式 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 ''' # 兩者結果是一樣的
import hmac import hashlib # key:密鑰 # msg:內容 # digestmod:加密的模式,默認是md5 h2 = hmac.new(key=b"satori", msg=b"satori", digestmod=hashlib.md5) print(h2.hexdigest()) ''' 3cba321fbb4e02c5b7e9fb7ef82bb47b ''' # 也可以通過update添加內容,是添加,不是覆蓋 h3 = hmac.new(key=b"satori") h3.update(b"satori") print(h3.hexdigest()) ''' 3cba321fbb4e02c5b7e9fb7ef82bb47b '''
import secrets # secrets貌似是python3.6里新增的模塊,先來看看api # secrets.choice(iterable),從可迭代對象里隨機選擇一個元素并返回 # secrets.randbelow(n),從[0,n)中隨機選擇一個數并返回 # secrets.randbits(k),返回帶有k個隨機位的整數 # secrets.token_bytes(nbytes=None),返回一個包含n個bytes的隨機字符串 # secrets.token_hex(nbytes=None),返回一個包含n個bytes的16進制隨機文本字符串,每個字節轉換成兩個16進制數字,一般用來生成隨即密碼 # secrets.token_urlsafe(nbytes=None),返回一個包含n個bytes的隨即url字符串,可以用來生成一個臨時的隨機令牌 # secrets.compare_digest(a, b),比較兩個字符串是否相等 print(secrets.choice("古明地盆")) # 古 print(secrets.choice(["satori", "mashiro", "nagisa"])) # nagisa # 和random.choice()是類似的 print(secrets.randbelow(8)) # 6 # 和random.randint()類似,但是secrets.randbelow()只能默認從零開始,且不包含右端點 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
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不同的是,會將一些字符進行一個替換 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")) # 古明地盆
from cryptography.fernet import Fernet # 生成秘鑰cipher_key cipher_key = Fernet.generate_key() # 傳入秘鑰實例化一個類 cipher = Fernet(cipher_key) text = '古明地覺'.encode("utf-8") #進行加密 encrypted_text = cipher.encrypt(text) print(type(encrypted_text)) # <class 'bytes'> #進行解密 decrypted_text = cipher.decrypt(encrypted_text) print(decrypted_text.decode("utf-8")) # 古明地覺
關于Python中有哪些常見的加密操作就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。