zoukankan      html  css  js  c++  java
  • hashlib(摘要算法的模块)--重要 (一)

    课件地址:https://www.cnblogs.com/mys6/p/10584933.html  搜索hashlib模块

    # 登录认证
    # 加密 --> 解密
    # 摘要算法
    # 两个字符串 :
    # import hashlib   # 提供摘要算法的模块
    # md5 = hashlib.md5()
    # md5.update(b'123456') 这里类型必须是byte类型
    # print(md5.hexdigest())
    #aee949757a2e698417463d47acac93df


    # 不管算法多么不同,摘要的功能始终不变
    # 对于相同的字符串使用同一个算法进行摘要,得到的值总是不变的
    # 使用不同算法对相同的字符串进行摘要,得到的值应该不同
    # 不管使用什么算法,hashlib的方式永远不变

    # import hashlib   # 提供摘要算法的模块
    # sha = hashlib.md5()
    # sha.update(b'alex3714')
    # print(sha.hexdigest())

    # sha 算法 随着 算法复杂程度的增加 我摘要的时间成本空间成本都会增加

    # 摘要算法
    # 密码的密文存储
    # 文件的一致性验证 (检验MD5后的值是否一样,平时文件下载安装时就会有个验证过程)
        # 在下载的时候 检查我们下载的文件和远程服务器上的文件是否一致
        # 两台机器上的两个文件 你想检查这两个文件是否相等

    # 用户注册
    # 用户 输入用户名
    # 用户输入 密码
    # 明文的密码进行摘要 拿到一个密文的密码
    # 写入文件

    # 用户的登录

    文本userinfo 》》"alex|aee949757a2e698417463d47acac93df|Teacher "


    # import hashlib
    # usr = input('username :')
    # pwd = input('password : ')
    # with open('userinfo') as f:
    #     for line in f:
    #         user,passwd,role = line.split('|')
    #         md5 = hashlib.md5()
    #         md5.update(bytes(pwd,encoding='utf-8'))
    #         md5_pwd = md5.hexdigest()
    #         if usr == user and md5_pwd == passwd:
    #             print('登录成功')


    # 1234567890挨个MD5加密
    # abcdefghijk挨个MD5加密放在一个库,然后去匹配普通加密的字窜实现简单的解密(就犹如百度MD5解密就这样来的)》》撞库
    # 6位
    # md5
    # 撞库

    # 加盐(为了杜绝解密)  盐(salt)盐可以随便输入、无固定,盐太简单也容易破解
    import hashlib   # 提供摘要算法的模块
    # md5 = hashlib.md5(bytes('盐',encoding='utf-8'))
    # # md5 = hashlib.md5()
    # md5.update(b'123456')
    # print(md5.hexdigest())

    # 动态加盐
    # 用户名 密码
    # 使用用户名的一部分或者 直接使用整个用户名作为盐
    # import hashlib   # 提供摘要算法的模块
    # md5 = hashlib.md5(bytes('盐',encoding='utf-8')+b'')
    # # md5 = hashlib.md5()
    # md5.update(b'123456')
    # print(md5.hexdigest())

    #import hashilib
    # 做摘要计算的 把字节类型的内容进行摘要处理
    # md5 sha
    # md5  正常的md5算法 加盐的 动态加盐


    # 文件的一致性校验
    # 文件的一致性校验这里不需要加盐
    # import hashlib
    # md5 = hashlib.md5()
    # md5.update(b'alex')
    # md5.update(b'3714')  #md5.update(b'alex3714')和md5.update(b'alex')、md5.update(b'3714') 分开使用摘要算法的结果print(md5.hexdigest())都是一样的
    # print(md5.hexdigest())

    当我们对一整片文章需要进行效验时需要所有文字一起去摘要算法,而是读一点就update,和全部文字一起update结果是一样的

    # 作业: 对一个文件进行摘要算法,最后计算出这个文件的md5值。

    SYS和OS搭配用法

  • 相关阅读:
    webpack配置
    gulp-babel 取消严格模式方法
    时间线
    tojson
    [[],[],[]]这样的数据转化成[{},{},{}]
    BUGFREE的安装
    Linux 打包压缩与搜索命令
    Linux 文件目录管理命令
    Linux 文本文件编辑命令
    Linux 工作目录切换命令
  • 原文地址:https://www.cnblogs.com/mys6/p/10720108.html
Copyright © 2011-2022 走看看