Python經常使用模塊之hashlib

Python裏面的hashlib模塊提供了不少加密的算法,這裏介紹一下hashlib的簡單使用事例,用hashlib的md5算法加密數據python

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('帳號不存在')

  這裏只簡單寫了一個用戶的註冊以及登錄網站

相關文章
相關標籤/搜索