#Hash,译做“散列”,也有直接音译为“哈希”的。把任意长度的输入,通过某种hash算法,变换成固定长度的输出,该输出就是散列值,也称摘要值。该算法就是哈希函数,也称摘要函数。
#MD5是最常见的摘要算法,速度很快,生成结果是固定的16字节,通常用一个32位的16进制字符串表示。SHA1算法更安全点,它的结果是20字节长度,通常用一个40位的16进制字符串表示。而比SHA1更安全的算法是SHA256和SHA512等等,不过越安全的算法越慢,并且摘要长度更长。
算法:
1、练习题一:
用户的注册以及登陆
hashlib
简单使用
import 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(r'C:\Users\Administrator\PycharmProjects\untitled\python\aaaa', '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('账号不存在')
import random #导入rangdom 模块
import string #导入string模块
import hashlib
def fun(): #定义一个函数
# num=string.digits+string.ascii_uppercase+string.ascii_lowercase
num =string.digits+string.ascii_letters
# 验证码:包含数字大小写字母,string模块可以实现那么先进行组合
# print(num)
a=random.sample(num,6)
#通过random模块中的sample方法来在num中随机取6个值
# print(a)
# print(''.join(a)) #通过join进行拼接输出返回一个组合
return ''.join(a)
fun() #函数调用函数
def fun1(): #定义一个函数
m_d5=fun() #函数的传递
md5=hashlib.md5() #通过hashlib.md5()来生成一个md5的对象
md5.update(m_d5.encode('utf-8')) #通过md5对象调用update方法来对某某实现加密的处理
print(md5.hexdigest())
fun1()