zoukankan      html  css  js  c++  java
  • hashlib

      什么是摘要算法呢?摘要算法又称哈希算法、散列算法。它通过一个函数,把任意长度的数据转换为一个长度固定的数据串(通常用16进制的字符串表示)。

    摘要算法就是通过摘要函数f()对任意长度的数据data计算出固定长度的摘要digest,目的是为了发现原始数据是否被人篡改过。

    摘要算法之所以能指出数据是否被篡改过,就是因为摘要函数是一个单向函数,计算f(data)很容易,但通过digest反推data却非常困难。而且,对原始数据做一个bit的修改,都会导致计算出的摘要完全不同。

    作用是 

     加密
    文件下载的时候,同过生成的哈希值来检验文件的一致性

    下面给出MD5,SHA1 俩种写法    

    MD5

    mport hashlib
     
    md5 = hashlib.md5()
    md5.update('how'.encode('utf-8'))
    print(md5.hexdigest())
     
    结果:db88a0257c220dbfdd2e40f6152d6a8d
    
    
    import hashlib
    # md5 = hashlib.md5('alex'.encode('utf-8'))
    # #加盐
    # md5.update('你好啊'.encode('utf-8'))
    # print(md5.hexdigest())
    
    
    
     

    SHA1  

    HA1的结果是160 bit字节,通常用一个40位的16进制字符串表示。

    SHA1的安全系数比MD5还要高一些,而且摘要的长度要比MD5长一些.

    比SHA1更安全的算法是SHA256和SHA512,不过越安全的算法越慢,而且摘要长度更长。

    import hashlib
     
    sha1 = hashlib.sha1()
    sha1.update('how to use sha1 in'.encode('utf-8'))
    sha1.update('python hashlib?'.encode('utf-8'))
    print(sha1.hexdigest())
     
    结果:86e1eae2a08c152d39b55baed085c71a0cc9d10b
    import hashlib
    s1 = hashlib.sha1('a'.encode('utf-8'))#加盐
    s1.update('你哈'.encode('utf-8'))
    print(s1.hexdigest())
    c9dbe3cd4bc5844de1d30403d98eeeec6008bcb2
    7e81cf96d8605215ad366063cd2abf7c6726018b
    安全   越长越慢 
  • 相关阅读:
    Electio Time poj
    排列的字典序问题
    poj 2365
    编程中的命名设计那点事(转)
    编程命名中的7+1个提示(转)
    poj 1664 放苹果——递归
    再论字典序
    poj 3618
    sort用法
    poj 1088
  • 原文地址:https://www.cnblogs.com/LMTlmt/p/10284279.html
Copyright © 2011-2022 走看看