标签:with 参数 因此 int hash pwd open python 验证
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(‘账号不存在‘)
标签:with 参数 因此 int hash pwd open python 验证
原文地址:https://www.cnblogs.com/tengfei520/p/8794492.html