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('帐号不存在')

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

相关文章
相关标签/搜索