Python md5與sha1加密演算法用法分析

2022-09-28 02:45:11 字數 1507 閱讀 5206

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: #開啟檔案,一定要以二進位制開啟www.cppcns.com

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

ps:關於加密解密感興趣的朋友還可以參考本站**工具:

文字**加密解密工具(包含aes、des、rc4等):

md5**加密工具:

**雜湊/雜湊演算法加密工具:

**md5/hash/sha-1/sha-2/sha-256/sha-512/sha-3/ripemd-160加密工具:

**sha1/sha224/sha256/sha384/sha512加密工具:

SHA 1與MD5的比較

因為二者均由md4匯出,sha 1和md5彼此很相似。相應的,他們的強度和其他特性也是相似,但還有以下幾點不同 l 對強行攻擊的安全性 最顯著和最重要的區別是sha 1摘要比md5摘要長32 位。使用強行技術,產生任何乙個報文使其摘要等於給定報摘要的難度對md5是2 128數量級的操作,而對sha ...

SHA1和md5的使用

sha1的全稱是secure hash algorithm 安全雜湊演算法 加密雜湊函式將任意長度的二進位制字串對映為固定長度的小型二進位制字串。加密雜湊函式有這樣乙個屬性 在計算上不大可能找到雜湊為相同的值的兩個不同的輸入 也就是說,兩組資料的雜湊值僅在對應的資料也匹配時才會匹配。資料的少量更改會...

PHP計算MD5和SHA1值

最近開發專案,需要用到檔案的md5和sha1值,這裡簡單地記錄下,備忘。md5的計算分為計算字串和檔案的md5值,sha1的計算分為計算字串和檔案的sha1值。php 4,php 5 md5 計算字串的 md5 雜湊值 report a bug string md5 string str bool ...