python hashlib_Python常用模块之hashlib

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())

如图为执行结果

python hashlib_Python常用模块之hashlib_第1张图片

这里写一个利用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('账号不存在')

这里只简单写了一个用户的注册以及登陆

你可能感兴趣的:(python,hashlib)