python MD5() 加密
摘要算法
python的hashlib提供了常见的摘要算法,如MD5,SHA1等等。
摘要算法又称哈希算法,散列算法。它通过一个函数,把任意长度的数据转换为一个长度固定的数据串(通常用16进制的字符串表示)。
摘要算法就是通过摘要函数 f() 对任意长度的数据 date计算出固定长度的摘要 digest,目的是为了发现原始数据是否被人篡改过。
我们以常见的摘要算法MD5为例,计算出一个字符串的MD5值:
import hashlib md5 = hashlib.md5() md5.update(‘how to user md5 in python hashlib?‘.encode(‘utf-8‘)) print(md5.hexdigest())
计算MD5值
计算结果如下:
4c850bdab2e3c34df385a2a228d2ea04
如果数据量很大,可以分多次调用 update() ,最后的计算结果都是一样的:
import hashlib md5 = hashlib.md5() md5.update(‘how to user md5 in ‘.encode(‘utf-8‘)) md5.update(‘python hashlib?‘.encode(‘utf-8‘)) print(md5.hexdigest())
分多次计算MD5值
计算结果:
4c850bdab2e3c34df385a2a228d2ea04
MD5是最常见的摘要算法,速度很快,生成结果是固定的128 bit字节,通常用一个32位的16进制字符串表示。
另一种常见的摘要算法是SHA1,调用SHA1和调用MD5完全类似:
import hashlib sha1 = hashlib.sha1() sha1.update(‘how to learning english?‘.encode(‘utf-8‘)) print(sha1.hexdigest())
计算sha1值
计算结果如下:
983b7e0be6b6d65fabf86149183c428da685d4a5
SHA1的结果是160 bit字节,通常用一个40位的16进制字符串表示。
由于常用口令的MD5值很容易被计算出来,所以,要确保存储的用户口令不是那些已经被计算出来的常用口令的MD5,这一方法通过对原始口令加一个复杂字符串来实现,俗称“加盐”:
应用:
import hashlib #导入模块
def get_md5(date):
obj = hashlib.md5(‘iuqe832643873gh‘.encode(‘utf-8‘)) #加盐iuqe832643873gh
obj.update(date.encode(‘utf-8‘)) # date 要加密的数据
result = obj.hexdigest()
return result
val = get_md5(‘123‘)
print(val)
USER_LIST = []
def register():
print(‘************用户注册************‘)
while True:
user = input(‘请输入用户名:‘)
if user == ‘N‘:
return
pwd = input(‘请输入密码:‘)
temp = {‘username‘: user, ‘password‘: get_md5(pwd)}
USER_LIST.append(temp)
def login():
print(‘************用户登陆************‘)
user = input(‘请输入用户名:‘)
pwd = input(‘请输入密码‘)
for item in USER_LIST:
if item[‘username‘] == user and item[‘password‘] == get_md5(pwd):
return True
register()
result = login()
if result:
print(‘登陆成功!‘)
else:
print(‘登陆失败!‘)模拟用户注册、登录