亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

詳解python中的hashlib模塊的使用

發布時間:2020-08-22 18:04:12 來源:腳本之家 閱讀:185 作者:一葉孤舟難罷休 欄目:開發技術

hashlib

hashlib主要提供字符加密功能,將md5和sha模塊整合到了一起,支持md5,sha1, sha224, sha256, sha384, sha512等算法

hashlib模塊

#哈希算法也叫摘要算法,相同的數據始終得到相同的輸出,不同的數據得到不同的輸出。
#(1)哈希將不可變的任意長度的數據,變成具有固定長度的唯一值
#(2)字典的鍵值對映射關系是通過哈希計算的,哈希存儲的數據是散列(無序)

# 應用場景:在需要效驗功能時使用
 用戶密碼的 => 加密,解密
 相關效驗的 => 加密,解密

hashlib中的MD5算法

# 第一步是引包
import hashlib
# 創建一個md5算法的對象
hs = hashlib.md5()
# print(hs)
# update中的 參數必須是二進制字節流 
hs.update("123".encode())
## hexdigest 返回32位十六進制的字符串(固定長度)
## 用一個hsvar來接收經過哈希算法返回的值
hsvar = hs.hexdigest()

#加鹽 (就是在簡單的算法中進行加入混肴參數)

語法格式如下:

#首先在實例化hashlib中的MD5對象的時候,加入混淆參數key,以此達到更加復雜的加密)

#加入的key參數一定也要是字節流
hs2 = hashlib.md5("abcd".encode())
hs2.update("123123".encode())
hs2var = hs2.hexdigest()

加鹽后的好處就是,增加了加密的安全性,使其不那么容易被破解

但因為hash算法是被公開的算法,其安全性不那么好,一些簡單的加密 值很容易被逆向破解出來,說逆向破解也不那么準確,

一般來說,破解此類算法只能使用窮舉法, 可以將 跑出來的值存入到一個大的數據庫中,哈希算法得出的值有唯一性,所以可以反向查詢已有的hash值來得到原始數據,當然這種網站也有, 我百度上看到的一個網站,你們可以進去看一看,一般的哈希值都能查詢到原數據,只要他們數據庫中有的話.

所以說最好的方法就是我們要加鹽,去加入復雜混肴參數,這樣的話大大提高了數據加密的安全性

鏈接: https://www.cmd5.com/  md5解密(本鏈接只作為學習使用,勿將其使用到任何非法用途)

在開發編程中,常用到hash算法的方面應該有用戶的注冊登錄

下面有我寫的一個實例,供大家參考(為了方便大家的閱讀,這個注冊登錄功能我沒有完善,比如說用正則去卡用戶名和密碼的格式等等,)

import hashlib
#定義一個加密函數,將傳入的參數轉換成32位的哈希值并返回
def md5(pwd):
  md5_password = hashlib.md5("abd".encode())
  md5_password.update(pwd.encode())
  return md5_password.hexdigest()
#定義一個登錄函數,將傳入的賬號密碼與本地密碼文件進行匹配,如果匹配到返回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
#定義一個注冊的函數,將用戶傳入的賬號密碼寫入到本地的密碼文件中
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是美國國家標準與技術研究院與美國國家安全局設計,從94年以來被廣泛使用的加密算法.sha系列中的sha1, sha224, sha2556適用于長度不超過2^64二進制位的消息。sha384和sha512適用于長度不超過2^128二進制位的消息。不過,這個也不太安全.2005年的時候國內王小云教授及其團隊在sha1算法的破譯上就已經取得了很大的成就.今年谷歌已經攻破了sha1算法.另外,Matthew Green(https://twitter.com/matthew_d_green)在這一領域也有不錯的成就.

import hashlib
#實例化sha1對象
hs3 = hashlib.sha1()
#去將要去加密的數據通過一個方法放入對象中
hs3.update('123123'.encode())
#調用對象中的方法,計算并輸出加密后的40位的哈希值
hsvar = hs3.hexdigest()

sha算法常用的有 sha1 sha512等,語法一樣,只不過輸出的哈希值的長度不一樣,所以就不一一列舉了

總結

以上所述是小編給大家介紹的python中的hashlib模塊的使用,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對億速云網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

江都市| 新昌县| 平泉县| 乌兰察布市| 当阳市| 洛南县| 昌江| 平江县| 武宁县| 凌海市| 鹤岗市| 伽师县| 东方市| 天峨县| 天台县| 那坡县| 乾安县| 临高县| 和龙市| 普宁市| 吉木乃县| 贺州市| 达日县| 东阿县| 威远县| 壤塘县| 大埔区| 西贡区| 收藏| 乌兰察布市| 遂川县| 济源市| 河南省| 赤壁市| 鄄城县| 五常市| 日土县| 忻城县| 公安县| 依安县| 富宁县|