盤點Python加密解密模塊hashlib的7種加密算法(推薦)

前言

在程序中我們經常可以看到有很多的加密算法,比如說MD5 sha1等,今天我們就來瞭解下這下加密算法的吧,在瞭解之前我們需要知道一個模塊嘛就是hashlib,他就是目前Python一個提供字符加密的模塊,它加密的字符類型為二進制編碼,所以直接加密字符串會報錯。

import hashlib 
string='任性的90後boy' 
#使用encode進行轉換 
sha1 = hashlib.sha1() 
sha1.update(string.encode('utf-8')) 
res = sha1.hexdigest() 
print("sha1采用encode轉換加密結果:",res) 
#使用byte轉換為二進制 
sha1 = hashlib.sha1() 
sha1.update(bytes(string,encoding='utf-8')) 
res = sha1.hexdigest() 
print("sha1采用byte轉換的結果:",res)

可以使用下列這兩種方法任意一種獲取到hashlib中所有的散列算法集合:

import hashlib 
a=hashlib.algorithms_available  
b=hashlib.algorithms_guaranteed 
print(a) 
print(b)

下面我們挑選常用的集中算法來進行講解。

一、MD5

MD5即Message-Digest Algorithm 5(信息-摘要算法5),用於確保信息傳輸完整一致。是計算機廣泛使用的雜湊算法之一(又譯摘要算法、哈希算法),主流編程語言普遍已有MD5實現。將數據(如漢字)運算為另一固定長度值,是雜湊算法的基礎原理,MD5的前身有MD2、MD3和MD4。

MD5算法具有以下特點:

1、壓縮性:任意長度的數據,算出的MD5值長度都是固定的。

2、容易計算:從原數據計算出MD5值很容易。

3、抗修改性:對原數據進行任何改動,哪怕隻修改1個字節,所得到的MD5值都有很大區別。

4、強抗碰撞:已知原數據和其MD5值,想找到一個具有相同MD5值的數據(即偽造數據)是非常困難的。

MD5的作用是讓大容量信息在用數字簽名軟件簽署私人密鑰前被”壓縮”成一種保密的格式(就是把一個任意長度的字節串變換成一定長的十六進制數字串)。MD5是最常見的摘要算法,速度很快,生成結果是固定的128 bit字節,通常用一個32位的16進制字符串表示。

import hashlib 
string='任性的90後boy' 
md5 = hashlib.md5()  
md5.update(string.encode('utf-8'))#轉碼,update裡的必須是字節型 
res = md5.hexdigest() #返回字符型摘要信息 
print(md5.digest())#返回字節型的摘要信息 
print("md5加密結果:",res)

二、sha1

安全散列算法,SHA1的結果是160 bit字節,通常用一個40位的16進制字符串表示

import hashlib 
string='任性的90後boy' 
sha1 = hashlib.sha1() 
sha1.update(string.encode('utf-8')) 
res = sha1.hexdigest() 
print("sha1加密結果:",res)

三、sha224

安全散列算法

import hashlib 
string='任性的90後boy' 
sha224 = hashlib.sha224() 
sha224.update(string.encode('utf-8')) 
res = sha224.hexdigest() 
print("sha224加密結果:",res)

四、sha256

安全散列算法

import hashlib 
string='任性的90後boy' 
sha256 = hashlib.sha256() 
sha256.update(string.encode('utf-8')) 
res = sha256.hexdigest() 
print("sha256加密結果:",res)

五、sha384

安全散列算法

import hashlib 
string='任性的90後boy' 
sha384 = hashlib.sha384() 
sha384.update(string.encode('utf-8')) 
res = sha384.hexdigest() 
print("sha384加密結果:",res)

六、sha512

安全散列算法

import hashlib 
string='任性的90後boy' 
sha512= hashlib.sha512() 
sha512.update(string.encode('utf-8')) 
res = sha512.hexdigest() 
print("sha512加密結果:",res)

七、高級加密

以上加密算法雖然依然非常厲害,但時候存在缺陷,即:通過撞庫可以反解。所以,有必要對加密算法中添加自定義key再來做加密。

md5 = hashlib.md5() 
md5.update('md5'.encode('utf-8')) 
res = md5.hexdigest() 
print("普通加密:",res) 
md51 = hashlib.md5(b'md512') 
md51.update('md51'.encode('utf-8')) 
res = md51.hexdigest() 
print("采用key加密:",res)

總結

好瞭,今天就跟大傢說這麼多,主要給大傢介紹瞭md5、sha1、sha224、sha256、sha384、sha512和高級加密等集中算法,簡單介紹瞭每個算法的特點和使用方法,後續精彩敬請期待!

到此這篇關於盤點Python加密解密模塊hashlib的7種加密算法的文章就介紹到這瞭,更多相關Python hashlib加密解密模塊內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀:

    None Found