Python里面的hashlib模塊提供了很多加密的算法,這里介紹一下hashlib的簡單使用事例,用hashlib的md5算法加密數據
import hashlib
hash = hashlib.md5()#md5對象,md5不能反解,但是加密是固定的,就是關系是一一對應,所以有缺陷,可以被對撞出來
hash.update(bytes('admin',encoding='utf-8'))#要對哪個字符串進行加密,就放這里
print(hash.hexdigest())#拿到加密字符串
# hash2=hashlib.sha384()#不同算法,hashlib很多加密算法
# hash2.update(bytes('admin',encoding='utf-8'))
# print(hash.hexdigest())
hash3 = hashlib.md5(bytes('abd',encoding='utf-8'))
''' 如果沒有參數,所以md5遵守一個規則,生成同一個對應關系,如果加了參數,
就是在原先加密的基礎上再加密一層,這樣的話參數只有自己知道,防止被撞庫,
因為別人永遠拿不到這個參數
'''
hash3.update(bytes('admin',encoding='utf-8'))
print(hash3.hexdigest())
如圖為執行結果

這里寫一個利用md5進行用戶登陸網站進行注冊之后密碼加密的基本事例,加深理解
#hashlib簡單使用
def md5(arg):#這是加密函數,將傳進來的函數加密
md5_pwd = hashlib.md5(bytes('abd',encoding='utf-8'))
md5_pwd.update(bytes(arg,encoding='utf-8'))
return md5_pwd.hexdigest()#返回加密的數據
def log(user,pwd):#登陸時候時候的函數,由於md5不能反解,因此登陸的時候用正解
with open('db','r',encoding='utf-8') as f:
for line in f:
u,p=line.strip().split('|')
if u ==user and p == md5(pwd):#登陸的時候驗證用戶名以及加密的密碼跟之前保存的是否一樣
return True
def register(user,pwd):#注冊的時候把用戶名和加密的密碼寫進文件,保存起來
with open('db','a',encoding='utf-8') as f:
temp = user+'|'+md5(pwd)
f.write(temp)
i=input('1表示登陸,2表示注冊:')
if i=='2':
user = input('用戶名:')
pwd =input('密碼:')
register(user,pwd)
elif i=='1':
user = user = input('用戶名:')
pwd =input('密碼:')
r=log(user,pwd)#驗證用戶名和密碼
if r ==True:
print('登陸成功')
else:
print('登陸失敗')
else:
print('賬號不存在')
這里只簡單寫了一個用戶的注冊以及登陸
