zoukankan      html  css  js  c++  java
  • hashlib标准库简单使用

    哈希算法/摘要算法是通过一个函数,把任意长度的数据转换为一个长度固定的数据串(通常用16进制的字符串表示)。
    该库对于不同的哈希算法/摘要算法都提供了通用的接口,比如FIPS算法中的SHA1,SHA224,SHA256,SHA512,还有RSA的MD5算法。
    对于每类哈希,创建方法都是创建以算法的名字为命名的对象,比如用sha256()就创建了SHA256哈希对象。可以用bytes对象对其进行初始化,然后用update()方法对其更新,最后可以调用digest()或者hexdigest()方法来查看哈希对象的信息摘要。

    import hashlib
    
    import numpy as np
    
    a=hashlib.md5(bytes('32',encoding='utf-8'))
    
    a.update(bytes('32',encoding='utf-8'))
    
    a.digest()
    
    b'x12xe0x86x06hx92xa3x11xb7Rg:(X=?'
    
    hashlib.md5(bytes('3232',encoding='utf-8')).digest()  #更紧凑的方法,与上面的经过分步update的a的信息摘要一致
    
    b'x12xe0x86x06hx92xa3x11xb7Rg:(X=?'
    
    len(hashlib.md5(bytes('3232',encoding='utf-8')).digest())
    
    16
    
    hashlib.md5(bytes('3232',encoding='utf-8')).digest()[0] #对照上面的16进位的信息摘要,可以发现第一个数字x12,确实是十进制的18
    
    18
    
    hashlib.md5(bytes('3232',encoding='utf-8')).hexdigest()
    
    '12e086066892a311b752673a28583d3f'
    

    MD5是最常见的摘要算法,速度很快,生成结果是固定的128 bit字节,通常用一个32位的16进制字符串表示。

    ##### 愿你一寸一寸地攻城略地,一点一点地焕然一新 #####
  • 相关阅读:
    故障分析 | 全局读锁一直没有释放,发生了什么?
    日常笔记
    BCC观测工具的使用
    wireshark的应用
    SQL基础之实现累加值
    SQL查询语句使用rand()的执行效率与优化
    MySQL主从复制相关问题
    LVM不停机扩容
    gtid跳过错误的方法
    IO诊断文档
  • 原文地址:https://www.cnblogs.com/johnyang/p/14493519.html
Copyright © 2011-2022 走看看