zoukankan      html  css  js  c++  java
  • Python之模块分类(五)

    一、hashlib模块

    用于加密相关的操作,3.x里代替了md5模块和sha模块,主要提供 SHA1, SHA224, SHA256, SHA384, SHA512 ,MD5 算法。

    #Author:Anliu
    import hashlib
    
    m = hashlib.md5()
    m.update(b"hello")
    print(m.hexdigest())
    m.update(b"world")
    print(m.hexdigest())
    #print(m.digest())
    m1 =hashlib.md5()
    m1.update(b"helloworld")
    print(m.hexdigest())
    # 同一个对象的加密是累加的
    #print(m.digest())  #二进制的方式加密
    #print(m.hexdigest())  #十六进制的方式加密
    
    m2 = hashlib.md5()
    m2.update("大中国".encode(encoding="utf-8"))
    print(m2.hexdigest())
    
    #带有中文的字符串要encode为bytes
    # ######## 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())

    二、hmac 模块

    散列消息鉴别码,简称HMAC,是一种基于消息鉴别码MAC(Message Authentication Code)的鉴别机制。使用HMAC时,消息通讯的双方,通过验证消息中加入的鉴别密钥K来鉴别消息的真伪;

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

    #Author:Anliu
    import hmac
    h = hmac.new("好好学习".encode(encoding="utf-8"))
    print(h.hexdigest())
  • 相关阅读:
    求解一元二次方程
    常用电脑软件
    c语言的布尔量
    unsigned int数据类型最大数
    int数据类型的最大数
    习题6-8 统计一行文本的单词个数
    习题6-6 使用函数输出一个整数的逆序数
    习题6-5 使用函数验证哥德巴赫猜想
    习题6-4 使用函数输出指定范围内的Fibonacci数
    C#委托、泛型委托
  • 原文地址:https://www.cnblogs.com/anttech/p/12714389.html
Copyright © 2011-2022 走看看