python中的md5和sha1加密算法使用

MD5
       MD5的全稱是Message-Digest Algorithm 5(信息-摘要算法),在90年代初由MIT Laboratory for 
Computer Science和RSA Data Security Inc的Ronald L. Rivest開發出來,經MD2、MD3和MD4發展而來。是一種不可逆的加密算法,目前是最牢靠的加密算法之一,尚沒有能夠逆運算的程序被開發出來,它對應任何字符串都可以加密成一段唯一的固定長度的代碼。
特性:

       首先,它不可逆,沒有系統的方法可以知道MD5碼原來的文字是什麼
   其次,這個碼具有高度的離散性,沒有規律可循。哪怕原信息的一點點變化就會導致MD5的巨大變化,
也可以說產生的MD5 碼是不可預測的。
   最後,由於這個碼有128位那麼長,所以任意信息之間具有相同MD5碼的可能性非常之低,通常被認爲是
不可能的。

用途:

       一般認爲MD5碼可以唯一地代表原信息的特徵,通常用於密碼的加密存儲,數字簽名,文件完整性驗證等 


SHA1

      SHA1的全稱是Secure Hash Algorithm(安全哈希算法) ,是由NIST NSA設計爲同DSA一起使用的,它對長度小於264的輸入,產生長度爲160bit的散列值,因此抗窮舉(brute-force)性更好。SHA-1 設計時基於和MD4相同原理,並且模仿了該算法。SHA-1是由美國標準技術局(NIST)頒佈的國家標準,是一種應用最爲廣泛的hash函數算法,也是目前最先進的加密技術,被政府部門和私營業主用來處理敏感的信息。而SHA-1基於MD5,MD5又基於MD4。
       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







發佈了30 篇原創文章 · 獲贊 6 · 訪問量 6萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章