zoukankan      html  css  js  c++  java
  • Python 基础

    hashlib模块介绍

    用于加密相关操作, 3.x 的hashlib提供了常见的哈希算法,主要封装MD5 和SHA系列模块。 哈希算法通过一个函数, 把任意长度的数据转为一个长度固定的数据串(通常是16进制)。这种加密算法包括SHA1, SHA224, SHA256, SHA384, SHA512,MD5等,SHA512比MD5更复杂严谨。

    主要隐喻

    其他相关加密模块:

    hmac 模块:它内部对我们创建 key 和 内容 再进行处理然后再加密。散列消息鉴别码,简称HMAC,是一种基于消息鉴别码MAC(Message Authentication Code)的鉴别机制。使用HMAC时,消息通讯的双方,通过验证消息中加入的鉴别密钥K来鉴别消息的真伪;

    一般用于网络通信中消息加密,前提是双方先要约定好key,就像接头暗号一样,然后消息发送把用key把消息加密,接收方用key + 消息明文再加密,拿加密后的值 跟 发送者的相对比是否相等,这样就能验证消息的真实性,及发送者的合法性了。

    常用操作

    此处以MD5算法为列:

    import hashlib
    
    m = hashlib.md5()
    m.update(b"hello")
    print(m.hexdigest())
    m.update(b"it is me")
    print(m.hexdigest())  # 代表 hello + it is me
    m.update(b"it's been a long time since we spoken")  # 返回16进制
    print(m.hexdigest())
    print(m.digest())  # 返回10进制
    m.update("天王盖地哭".encode(encoding="utf-8"))  # 中文需要encoding
    print(m.hexdigest())
    MD5

    其他:

    import hashlib
    
     
    
    # ######## md5 ########
    hash = hashlib.md5()
    hash.update('admin')
    print(hash.hexdigest())
     
    
    # ######## sha1 ########
    hash = hashlib.sha1()
    hash.update('admin')
    print(hash.hexdigest())
    
     
    # ######## sha256 ########
    hash = hashlib.sha256()
    hash.update('admin')
    print(hash.hexdigest())
    
     
    # ######## sha384 ########
    hash = hashlib.sha384()
    hash.update('admin')
    print(hash.hexdigest())
    
     
    # ######## sha512 ########
    hash = hashlib.sha512()
    hash.update('admin')
    print(hash.hexdigest())
    加密算法
  • 相关阅读:
    c# 多线程系列二 自定义线程执行器
    博客人生
    c#实现分组服务器,单一无重复生成ID
    c# 游戏策划配置工具
    tar命令
    maven的一些使用技巧
    FSCapture截图工具
    删除已经跟踪的文件夹的版本控制
    idea模板的设置
    centos安装sublime
  • 原文地址:https://www.cnblogs.com/lg100lg100/p/7414453.html
Copyright © 2011-2022 走看看