Python 常見加密操作的實現(xiàn)
import hashlib # 有很多種加密方式,md5,sha1等等h = hashlib.md5()# 提交加密的內(nèi)容,bytes形式h.update(b'satori')# 二進(jìn)制形式print(h.digest())’’’b’x13xd54x0f:xdfx8e[xe0x83xddxc6xcaxd2Gxb8’’’’# 十六進(jìn)制形式print(h.hexdigest())’’’13d5340f3adf8e5be083ddc6cad247b8’’’
import hashlib # 相對的,還有簡便的操作# 直接指定要加密的字符串h1 = hashlib.md5(b'satori')print(h1.hexdigest())’’’13d5340f3adf8e5be083ddc6cad247b8’’’ h2 = hashlib.md5()h2.update(b'satori')print(h2.hexdigest())’’’13d5340f3adf8e5be083ddc6cad247b8’’’# 兩者結(jié)果是一樣的hmac加密
import hmacimport hashlib # key:密鑰# msg:內(nèi)容# digestmod:加密的模式,默認(rèn)是md5h1 = hmac.new(key=b'satori', msg=b'satori', digestmod=hashlib.md5)print(h1.hexdigest())’’’3cba321fbb4e02c5b7e9fb7ef82bb47b’’’ # 也可以通過update添加內(nèi)容,是添加,不是覆蓋h2 = hmac.new(key=b'satori')h2.update(b'satori')print(h2.hexdigest())’’’3cba321fbb4e02c5b7e9fb7ef82bb47b’’’secrets
import secrets # secrets貌似是python3.6里新增的模塊,先來看看api# secrets.choice(iterable),從可迭代對象里隨機(jī)選擇一個元素并返回# secrets.randbelow(n),從[0,n)中隨機(jī)選擇一個數(shù)并返回# secrets.randbits(k),返回帶有k個隨機(jī)位的整數(shù)# secrets.token_bytes(nbytes=None),返回一個包含n個bytes的隨機(jī)字符串# secrets.token_hex(nbytes=None),返回一個包含n個bytes的16進(jìn)制隨機(jī)文本字符串,每個字節(jié)轉(zhuǎn)換成兩個16進(jìn)制數(shù)字,一般用來生成隨即密碼# secrets.token_urlsafe(nbytes=None),返回一個包含n個bytes的隨即url字符串,可以用來生成一個臨時的隨機(jī)令牌# 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()只能默認(rèn)從零開始,且不包含右端點 print(secrets.randbits(7)) # 96 print(secrets.token_bytes()) # b’x87x98x1cx80TOxcfx82xc9xf1xd6xf6fxd7xd7xaexea.xfd0yxd6xafxfbexb4vx8b@xc8txe6’print(secrets.token_bytes(nbytes=20)) # b’xa5:(xf2xcbxb2xd8xbcexacnx8cx95x05:x07e#xa7M’ print(secrets.token_hex()) # 0904e492deaab1270f11671d687f3bb2c7ead5283bfe55a3b51e560101c38828print(secrets.token_hex(20)) # 851801ed1367bc946b1f28812a83a7e84d91908e print(secrets.token_urlsafe()) # sGGhrL8VLECMYalQ5DHMDm0yugoVsr2M-SvN4z2Qk8kprint(secrets.token_urlsafe(nbytes=20)) # PIvP0VoRxvfignT1MH_p2vNog9Ubase64
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)行一個替換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_keycipher_key = Fernet.generate_key() # 傳入秘鑰實例化一個類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')) # 古明地覺
以上就是Python 常見加密操作的實現(xiàn)的詳細(xì)內(nèi)容,更多關(guān)于python 加密操作的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!
相關(guān)文章:
1. Spring security 自定義過濾器實現(xiàn)Json參數(shù)傳遞并兼容表單參數(shù)(實例代碼)2. Java8內(nèi)存模型PermGen Metaspace實例解析3. 多級聯(lián)動下拉選擇框,動態(tài)獲取下一級4. ASP.NET MVC使用正則表達(dá)式驗證手機(jī)號碼5. Python 中random 庫的詳細(xì)使用6. Spring注入Date類型的三種方法總結(jié)7. ASP新手必備的基礎(chǔ)知識8. XML和JSP的聯(lián)手9. Python基于百度AI實現(xiàn)抓取表情包10. Python使用sftp實現(xiàn)上傳和下載功能
