python3.x和2.x在使用md5加密上有点不一样。首先2.x时期的md5模块已经没了,要想使用md5加密,则需要使用hashlib模块,是语法上也有点不一样。
github:https://github.com/Fu4ng/PythonStudy/tree/master/Md5
import hashlib
#md5加密的方式
hash = hashlib.md5()
hash.update(bytes('要加密的东西', encoding='utf-8'))
print(hash.hexdigest())#md5码
有的人会使用两次加密来确保不会撞库,在第二次加密时使用的参数只有自己知道,大大加强了安全性。
#一个小程序,在登录注册方面还有一些bug
# 利用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.readlines():
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) + '\n'
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('账号不存在')