• python的hashlib加密


    看别人的文章,抄成自己的,我用的是python3

    简单了解是怎么用:

    import hashlib
    
    hash = hashlib.md5()  # md5对象,md5不能反解,但是加密是固定的,就是关系是一一对应,所以有缺陷,可以被对撞出来
    hash.update(bytes('admin', encoding='utf-8'))  # 要对哪个字符串进行加密,就放这里
    print(hash.hexdigest())  # 拿到加密字符串

    结果如下:

     1 21232f297a57a5a743894a0e4a801fc3   

    用户密码加密保存:

    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('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('账号不存在')
    

      

  • 相关阅读:
    WinForm 下的 Wizard(向导) 控件, 提供设计时支持!
    关于安装VS2005或MSDN时遇到“Please insert the disk:XXXXXXX” 错误提示的解决方法!
    Welcome
    Latex 入门教程
    图形学 旋转与投影矩阵3
    图形学 旋转与投影矩阵—2
    算法希尔排序可视化
    图形学 旋转与投影矩阵—1
    BlinnPhong反射模型实践(web实现)
    贝塞尔曲线(面)二三维可视化(Three+d3)
  • 原文地址:https://www.cnblogs.com/litzhiai/p/7656437.html
Copyright © 2020-2023  润新知