這篇文章主要介紹了Python hashlib常見摘要算法詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
Python的hashlib提供了常見的摘要算法,如MD5,SHA1等等
計算出一個字符串的MD5值:
1
2
3
4
5
6
7
8
9
10
11
|
import hashlib md5 = hashlib.md5() md5.update( 'how to use md5 in python hashlib?' .encode( "utf8" )) #需要指定轉(zhuǎn)碼 否則報錯 update()必須指定要加密的字符串的字符編碼 print ( md5.hexdigest()) #返回十六進(jìn)制 print ( md5.digest()) #二進(jìn)制 # 如果數(shù)據(jù)量很大,可以分塊多次調(diào)用update(),最后計算的結(jié)果是一樣的: md5 = hashlib.md5() md5.update( 'how to use md5 in ' .encode( "utf8" )) md5.update( 'python hashlib?' .encode( "utf8" )) print ( md5.hexdigest()) #返回十六進(jìn)制 |
上述結(jié)果:
1
2
3
|
d26a53750bc40b38b65a520292f69306 b'\xd2jSu\x0b\xc4\x0b8\xb6ZR\x02\x92\xf6\x93\x06' d26a53750bc40b38b65a520292f69306 |
計算出一個字符串SHA1值:
1
2
3
4
5
6
7
8
9
10
|
import hashlib sha_1 = hashlib.sha1() sha_1.update( 'how to use sha1 in ' .encode( "utf8" )) #需要指定轉(zhuǎn)碼 否則報錯 update()必須指定要加密的字符串的字符編碼 sha_1.update( 'python hashlib?' .encode( "utf8" )) print (sha_1.hexdigest()) # 如果數(shù)據(jù)量很大,可以分塊多次調(diào)用update(),最后計算的結(jié)果是一樣的: sha2 = hashlib.sha1() sha2.update( 'how to use sha1 in python hashlib?' .encode( "utf8" )) print (sha2.hexdigest()) |
打印結(jié)果:
2c76b57293ce30acef38d98f6046927161b46a44
2c76b57293ce30acef38d98f6046927161b46a44
讀取文件獲取MD5值:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
import os import hashlib #文件md5 def file_md5(pathandname): if os.path.isfile(pathandname): hashmd5 = hashlib.md5() file = open (pathandname, 'rb' ) while True : b = file .read( 1024 ) if not b: break hashmd5.update(b) file .close() return hashmd5.hexdigest() else : return None print (file_md5( "C:\\Users\\Administrator\\Desktop\\V2.6.1_B511\\hvr_dec" )) #aef87d1d673ca52412b4a950a06b9557 |
讀取文件base64
1
2
3
4
5
6
7
8
9
10
|
import base64 import os # base64,參數(shù)為文件路徑名 def file_base64(filepath): if os.path.isfile(filepath): with open (filepath, 'rb' ) as file : file_base64_str = base64.b64encode( file .read()) return file_base64_str else : return None |
讀取sha256
1
2
3
4
5
6
7
|
import hmac import hashlib def get_hmacsha256(key, message): key_bytes = bytes(key, 'utf-8' ) message_bytes = bytes(message, 'utf-8' ) hmacsha256_str = hmac.new(key_bytes, message_bytes, digestmod = hashlib.sha256).hexdigest() return hmacsha256_str |
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。
原文鏈接:https://www.cnblogs.com/carey9420/p/12179496.html