詳解python中的hashlib模塊的使用
hashlib
hashlib主要提供字符加密功能,將md5和sha模塊整合到了一起,支持md5,sha1, sha224, sha256, sha384, sha512等算法
hashlib模塊
#哈希算法也叫摘要算法,相同的數(shù)據(jù)始終得到相同的輸出,不同的數(shù)據(jù)得到不同的輸出。
#(1)哈希將不可變的任意長度的數(shù)據(jù),變成具有固定長度的唯一值
#(2)字典的鍵值對映射關(guān)系是通過哈希計算的,哈希存儲的數(shù)據(jù)是散列(無序)
# 應(yīng)用場景:在需要效驗功能時使用
用戶密碼的 => 加密,解密
相關(guān)效驗的 => 加密,解密
hashlib中的MD5算法
# 第一步是引包 import hashlib # 創(chuàng)建一個md5算法的對象 hs = hashlib.md5() # print(hs) # update中的 參數(shù)必須是二進制字節(jié)流 hs.update("123".encode()) ## hexdigest 返回32位十六進制的字符串(固定長度) ## 用一個hsvar來接收經(jīng)過哈希算法返回的值 hsvar = hs.hexdigest()
#加鹽 (就是在簡單的算法中進行加入混肴參數(shù))
語法格式如下:
#首先在實例化hashlib中的MD5對象的時候,加入混淆參數(shù)key,以此達到更加復(fù)雜的加密) #加入的key參數(shù)一定也要是字節(jié)流 hs2 = hashlib.md5("abcd".encode()) hs2.update("123123".encode()) hs2var = hs2.hexdigest()
加鹽后的好處就是,增加了加密的安全性,使其不那么容易被破解
但因為hash算法是被公開的算法,其安全性不那么好,一些簡單的加密 值很容易被逆向破解出來,說逆向破解也不那么準確,
一般來說,破解此類算法只能使用窮舉法, 可以將 跑出來的值存入到一個大的數(shù)據(jù)庫中,哈希算法得出的值有唯一性,所以可以反向查詢已有的hash值來得到原始數(shù)據(jù),當然這種網(wǎng)站也有, 我百度上看到的一個網(wǎng)站,你們可以進去看一看,一般的哈希值都能查詢到原數(shù)據(jù),只要他們數(shù)據(jù)庫中有的話.
所以說最好的方法就是我們要加鹽,去加入復(fù)雜混肴參數(shù),這樣的話大大提高了數(shù)據(jù)加密的安全性
鏈接: https://www.cmd5.com/ md5解密(本鏈接只作為學(xué)習(xí)使用,勿將其使用到任何非法用途)
在開發(fā)編程中,常用到hash算法的方面應(yīng)該有用戶的注冊登錄
下面有我寫的一個實例,供大家參考(為了方便大家的閱讀,這個注冊登錄功能我沒有完善,比如說用正則去卡用戶名和密碼的格式等等,)
import hashlib #定義一個加密函數(shù),將傳入的參數(shù)轉(zhuǎn)換成32位的哈希值并返回 def md5(pwd): md5_password = hashlib.md5("abd".encode()) md5_password.update(pwd.encode()) return md5_password.hexdigest() #定義一個登錄函數(shù),將傳入的賬號密碼與本地密碼文件進行匹配,如果匹配到返回True def login(user,pwd): with open("database","r",encoding="utf-8") as fp: for line in fp : u,p = line.strip().split("|") if u == user and p == md5(pwd): return True #定義一個注冊的函數(shù),將用戶傳入的賬號密碼寫入到本地的密碼文件中 def register(user,pwd): with open("database","w",encoding="utf-8") as fp: temp = user+ "|" + md5(pwd) fp.write(temp) #index菜單,給用戶的交互 choice = input("1表示登錄, 2表示注冊:").strip() if choice == "2": user = input("用戶名:") pwd = input("密碼:") register(user,pwd) elif choice == "1": user = input("用戶名:") pwd = input("密碼:") r = login(user,pwd) if r == True: print("登錄成功") else: print("登錄失敗") else: print("賬號不存在")
hashlib中的sha算法
•# sha 加密效率低,算法精密,安全性高
•sha: Secure Hash Algorithm(安全哈希算法)
sha是美國國家標準與技術(shù)研究院與美國國家安全局設(shè)計,從94年以來被廣泛使用的加密算法.sha系列中的sha1, sha224, sha2556適用于長度不超過2^64二進制位的消息。sha384和sha512適用于長度不超過2^128二進制位的消息。不過,這個也不太安全.2005年的時候國內(nèi)王小云教授及其團隊在sha1算法的破譯上就已經(jīng)取得了很大的成就.今年谷歌已經(jīng)攻破了sha1算法.另外,Matthew Green(https://twitter.com/matthew_d_green)在這一領(lǐng)域也有不錯的成就.
import hashlib #實例化sha1對象 hs3 = hashlib.sha1() #去將要去加密的數(shù)據(jù)通過一個方法放入對象中 hs3.update('123123'.encode()) #調(diào)用對象中的方法,計算并輸出加密后的40位的哈希值 hsvar = hs3.hexdigest()
sha算法常用的有 sha1 sha512等,語法一樣,只不過輸出的哈希值的長度不一樣,所以就不一一列舉了
總結(jié)
以上所述是小編給大家介紹的python中的hashlib模塊的使用,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!
- 盤點Python加密解密模塊hashlib的7種加密算法(推薦)
- Python hashlib和hmac模塊使用方法解析
- Python hashlib模塊的使用示例
- Python字符串hashlib加密模塊使用案例
- Python加密模塊的hashlib,hmac模塊使用解析
- Python hashlib模塊實例使用詳解
- Python hashlib加密模塊常用方法解析
- python模塊hashlib(加密服務(wù))知識點講解
- Python hashlib模塊加密過程解析
- Python3.5內(nèi)置模塊之shelve模塊、xml模塊、configparser模塊、hashlib、hmac模塊用法分析
- Python基礎(chǔ)之hashlib模塊詳解
相關(guān)文章
python實現(xiàn)獲取客戶機上指定文件并傳輸?shù)椒?wù)器的方法
這篇文章主要介紹了python實現(xiàn)獲取客戶機上指定文件并傳輸?shù)椒?wù)器的方法,涉及Python實現(xiàn)C/S架構(gòu)程序與socket程序的使用技巧,需要的朋友可以參考下2015-03-03詳解Ubuntu16.04安裝Python3.7及其pip3并切換為默認版本
這篇文章主要介紹了詳解Ubuntu16.04安裝Python3.7及其pip3并切換為默認版本,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-02-02python機器學(xué)習(xí)理論與實戰(zhàn)(六)支持向量機
這篇文章主要介紹了python機器學(xué)習(xí)理論與實戰(zhàn)第六篇,支持向量機的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-01-01python 實現(xiàn)提取log文件中的關(guān)鍵句子,并進行統(tǒng)計分析
今天小編就為大家分享一篇python 實現(xiàn)提取log文件中的關(guān)鍵句子,并進行統(tǒng)計分析,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-12-12關(guān)于keras中keras.layers.merge的用法說明
這篇文章主要介紹了關(guān)于keras中keras.layers.merge的用法說明,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-05-05