1、hashlib模塊
一、什麼叫hash:hash是一種算法(3.x裏代替了md5模塊和sha模塊,主要提供 SHA1, SHA224, SHA256, SHA384, SHA512 ,MD5 算法),該算法接受傳入的內容,通過運算獲得一串hash值 二、hash值的特色是: 2.1 只要傳入的內容同樣,獲得的hash值必然同樣=====>要用明文傳輸密碼文件完整性校驗 2.2 不能由hash值返解成內容=======》把密碼作成hash值,不該該在網絡傳輸明文密碼 2.3 只要使用的hash算法不變,不管校驗的內容有多大,獲得的hash值長度是固定的
hash算法就像一座工廠,工廠接收你送來的原材料(能夠用m.update()爲工廠運送原材料),通過加工返回的產品就是hash值html
import hashlib #m=hashlib.md5() #m.update(b'hello') #print(m.hexdigest()) #也能夠直接寫b開頭 m=hashlib.md5() # m=hashlib.sha256() m.update('hello'.encode('utf8')) print(m.hexdigest()) #5d41402abc4b2a76b9719d911017c592 m.update('alvin'.encode('utf8')) print(m.hexdigest()) #92a7e713c30abbb0319fa07da2a5c4af m2=hashlib.md5() m2.update('helloalvin'.encode('utf8')) print(m2.hexdigest()) #92a7e713c30abbb0319fa07da2a5c4af #注意:把一段很長的數據update屢次,與一次update這段長數據,獲得的結果同樣 可是update屢次爲校驗大文件提供了可能。
以上加密算法雖然依然很是厲害,但時候存在缺陷,即:經過撞庫能夠反解。因此,有必要對加密算法中添加自定義key再來作加密,也叫加鹽。python
#密碼加鹽 import hashlib pwd='qianduoduo123' m=hashlib.md5() m.update('天王蓋地虎'.encode('utf-8')) m.update(pwd.encode('utf-8')) m.update('寶塔鎮河妖'.encode('utf-8')) print(m.hexdigest())
python 還有一個 hmac 模塊,它內部對咱們建立 key 和 內容 進行進一步的處理而後再加密:算法
import hmac h = hmac.new('alvin'.encode('utf8')) h.update('hello'.encode('utf8')) print (h.hexdigest())#320df9832eab4c038b6c1d7ed73a5940
要想保證hmac最終結果一致,必須保證: 1:hmac.new括號內指定的初始key同樣 2:不管update多少次,校驗的內容累加到一塊兒是同樣的內容
2、suprocess模塊
#windows下: import subprocess obj=subprocess.Popen('dir', shell=True, stdout=subprocess.PIPE, stderr=subprocess.PIPE ) res1=obj.stdout.read() print('正確結果1111: ',res1) res2=obj.stdout.read() print('正確結果2222: ',res2) #只能取一次,取走了就沒有了 res2=obj.stderr.read() print('錯誤結果:',res2.decode('gbk')) #subprocess使用當前系統默認編碼,獲得結果爲bytes類型,在windows下須要用gbk解碼