Python hashlib加密模块常用方法解析
作者:新兵蛋子
这篇文章主要介绍了Python hashlib加密模块常用方法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
这篇文章主要介绍了Python hashlib加密模块常用方法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
主要用于对字符串的加密,最常用的为MD5加密:
import hashlib def get_md5(data): obj = hashlib.md5() obj.update(data.encode('utf-8')) result = obj.hexdigest() return result val = get_md5('123') #这里放入要加密的字符串文字。 print(val)
如果要避免撞库的行为,可以加盐将加密数值改为更加复杂的,这样破译起来更加不容易。
import hashlib def get_md5(data): obj = hashlib.md5('abclasjd;flasdkfhowheofwa123113'.encode('utf-8')) #这里加盐 obj.update(data.encode('utf-8')) result = obj.hexdigest() return result val = get_md5('123') #这里放入要加密的字符串文字。 print(val)
案例:
说明:用户输入新建的用户名和密码,以MD5加密的形式存入文件中。再让用户输入用户名密码进行匹配。
#!/usr/bin/env python # _*_ coding=utf-8 _*_ import hashlib def get_md5(data): ''' 登录加密,将传入的密码进行加密处理,并返回值。 :param data: 用户的密码 :return: 返回MD5加密后的密码 ''' obj = hashlib.md5('abclasjd;flasdkfhowheofwa123113'.encode('utf-8')) #这里加盐 obj.update(data.encode('utf-8')) result = obj.hexdigest() return result def seve_user(username,password): ''' 将加密后的密码和用户名进行保存,以| 来分割,文件为test.txt :param username: 需要创建的用户名 :param password: MD5后的密码 :return: 需要更改的地方,return判断是否保存成功。 ''' user_list = [username,get_md5(password)] lis = '|'.join(user_list) with open('test.txt',encoding='utf-8',mode='a')as f: f.write(lis+'\n') def read_user(username,password): ''' 来判断用户登录所输入的用户名和是否正确。 :param username: 用户输入的用户名 :param password: MD5加密后的密码 :return: 如果匹配返回True ''' with open('test.txt',mode='r',encoding='utf-8') as f: for item in f: infomation = item.strip() user,pwd = infomation.split('|') if username == user and password == pwd: return True while True: ''' 循环需要创建的用户 ''' user =input('请输入用户名:') if user.upper() == 'N': break pwd = input('请输入密码:') if len(user) and len(pwd) < 8: print('用户名密码不符合要求,请重新输入。') else: seve_user(user,pwd) while True: ''' 循环用户登录 ''' user_name = input('请输入用户名:') password = input('请输入密码:') start_user = read_user(user_name,get_md5(password)) if start_user: print('登录成功') break else: print('登录失败')
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。