zoukankan      html  css  js  c++  java
  • [转] python 模块学习 hashlib

    转自: http://www.cnblogs.com/BeginMan/p/3328172.html

    一、hashlib概述

    涉及加密服务:14. Cryptographic Services

    其中 hashlib是涉及安全散列和消息摘要,提供多个不同的加密算法借口,如SHA1、SHA224、SHA256、SHA384、SHA512、MD5等。

    二、快速入门

    import hashlib
    m = hashlib.md5()   #创建hash对象,md5:(message-Digest Algorithm 5)消息摘要算法,得出一个128位的密文
    print m             #<md5 HASH object @ 000000000254ADF0>
    m.update('BeginMan')#更新哈希对象以字符串参数
    print m.digest()    #返回摘要,作为二进制数据字符串值
    print m.hexdigest() #返回十六进制数字字符串    0b28251e684dfbd9102f8b6f0281c0c5
    print m.digest_size #16
    print m.block_size  #64

    使用new()创建指定加密模式的hash对象

    new(name, string='')
         """
         Return a new hashing object using the named algorithm;
         optionally initialized with a string.
         """
    h = hashlib.new('md5')
    print h     #<md5 HASH object @ 000000000260BDB0>
    h2 = hashlib.new('ripemd160','what')
    print h2    #<ripemd160 HASH object @ 000000000271B9F0>
    h.update('beginman')
    print h.hexdigest() #666fc5baa93a7fb207c5bfff03b67732
    #等效
    s = hashlib.md5()
    s.update('beginman')
    print s.hexdigest() #666fc5baa93a7fb207c5bfff03b67732
    
    print h2.hexdigest()    #9c1185a5c5e9fc54612808977ee8f548b2258d31

    三、常用属性

    #属性
    print hashlib.algorithms    #('md5', 'sha1', 'sha224', 'sha256', 'sha384', 'sha512')    列出所有加密算法
    print h.digest_size         #16 产生的散列的字节大小。 
    print h.block_size          #64 The internal block size of the hash algorithm in bytes.

    四、常用方法

    hash.update(arg)

    更新哈希对象以字符串参数,如果同一个hash对象重复调用该方法,则m.update(a); m.update(b) is equivalent to m.update(a+b).

    hash.digest()

    返回摘要,作为二进制数据字符串值,

    hash.hexdigest()

    返回摘要,作为十六进制数据字符串值,

    hash.copy()

    复制

    五、应用实例

    注册、登录、文件上传、相册加密....

    import datetime
    KEY_VALUE = '/BeginMan/'
    now = datetime.datetime.now()
    m = hashlib.md5()
    str = '%s%s' %(KEY_VALUE,now.strftime("%Y%m%d"))
    m.update(str)
    value = m.hexdigest()
    print value #8db42d3e90b41105ed061b8347a7c850
  • 相关阅读:
    SPFA算法——香甜的黄油
    并查集及应用
    背包问题——装箱问题(洛谷1049)用true模板
    划分类动态规划——乘积最大(洛谷1018,codevs1017)
    多源最短路Floyed——多源最短路(CODEVS1077)(可能Floyed模板)
    并查集——亲戚(洛谷1551)(可做并查集模板)
    最小生成树Kruskal——最优布线问题(codevs 1231) (可做Kruscal模板)
    最小生成树Prim——最短网络(洛谷1546)(USACO 3.1.1)可当Prim模板
    lsy263 の CSP-S 2019游记
    About Me
  • 原文地址:https://www.cnblogs.com/piperck/p/5377790.html
Copyright © 2011-2022 走看看