python中的md5和sha1加密演算法使用
阿新 • • 發佈:2019-02-08
MD5
MD5的全稱是Message-Digest Algorithm 5(資訊-摘要演算法),在90年代初由MIT Laboratory for Computer Science和RSA Data Security Inc的Ronald L. Rivest開發出來,經MD2、MD3和MD4發展而來。是一種不可逆的加密演算法,目前是最牢靠的加密演算法之一,尚沒有能夠逆運算的程式被開發出來,它對應任何字串都可以加密成一段唯一的固定長度的程式碼。
特性:
首先,它不可逆,沒有系統的方法可以知道MD5碼原來的文字是什麼
其次,這個碼具有高度的離散性,沒有規律可循。哪怕原資訊的一點點變化就會導致MD5的巨大變化,
最後,由於這個碼有128位那麼長,所以任意資訊之間具有相同MD5碼的可能性非常之低,通常被認為是不可能的。
用途:
一般認為MD5碼可以唯一地代表原資訊的特徵,通常用於密碼的加密儲存,數字簽名,檔案完整性驗證等
SHA1
SHA1的全稱是Secure Hash Algorithm(安全雜湊演算法) ,是由NIST NSA設計為同DSA一起使用的,它對長度小於264的輸入,產生長度為160bit的雜湊值,因此抗窮舉(brute-force)性更好。SHA-1 設計時基於和MD4相同原理,並且模仿了該演算法。SHA-1是由美國標準技術
SHA-1比MD5多32位密文,所以更安全。由於同樣的原因,MD5比SHA-1的運算速度更快。
用法例項:
python中的hashlib模組是個專門提供hash演算法的庫,現在裡面包括md5, sha1, sha224, sha256, sha384, sha512,使用非常簡單、方便。用法如下:
import hashlib hash_new = hashlib.sha1() #或hashlib.md5() with open('driver.xml.tar.bz2','rb') as fp: #開啟檔案,一定要以二進位制開啟 while True: data = fp.read() #讀取檔案塊 if not data: #直到讀完檔案 break hash_new.update(data) hash_value = hash_new.hexdigest() #生成40位(sha1)或32位(md5)的十六進位制字串 print hash_value