首頁  >  文章  >  後端開發  >  Python md5與sha1加密演算法的詳細介紹

Python md5與sha1加密演算法的詳細介紹

零下一度
零下一度原創
2017-07-16 13:55:052939瀏覽

這篇文章簡單介紹了md5級sha1加密演算法的概念、原理,並結合實例形式分析了Python使用hashlib模組實現加密功能的具體操作技巧,需要的朋友可以參考下

如果,md5和sha1加密的內容過多,可以這麼用:

[python]  
m = hashlib.md5()  
m.update('a')  
m.update('b')  
s = m.hexdigest()  
#效果等于m = hashlib.md6('ab').hexd

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

以上是Python md5與sha1加密演算法的詳細介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn