当前位置 主页 > 网站技术 > 代码类 >

    Python内置加密模块用法解析

    栏目:代码类 时间:2019-11-25 15:11

    这篇文章主要介绍了Python内置加密模块用法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

    数据加密:

    对称加密:数据加密和解密使用相同的密钥,主要解决数据的机密性(DES,AES) 非对称加密(公匙加密):数据加密和解密使用的不同密钥,主要用于身份的验证(DSA,RSA) 单向加密:只能加密不能解密,主要用于解决数据的完整性(MD5,SHA系列算法)

    Python内置加密模块:

    hashlib 主要提供了一些常见的单向加密算法(如MD5,SHA等)
    hmac 单向加密算法,支持设置一个额外的密匙(salt)来提高安全性
    secrets Python3.6新增用于获取安全随机数

    1.hashlib 模块

    其中主要包含了MD5和SHA模块的功能,还提供了如MD5,SHA1,SHA224,SHA256,SHA384和SHA512(输出长度不同)等算法的函数实现

    hashlib模块包含的函数与属性:

    hashlib.new(name[,data]) 用于构造指定的哈希算法所对应的哈希对象,name可用于指定哈希算法的名称,如‘MD5',‘sha1',不分大小写,data为一个可选参数
    hashlib.algorithms_guaranteed 它的值是一个该模块在所有平台都会支持的哈希算法的名称集合:set(['sha1','sha224','sha384','sha256','sha512','md5'])
    hashlib.algorithms_available 它的值是一个当前运行的Python解释器中可用的哈希算法的名称集合,algorithms_guaranteed将永远是它的子集

    hash对象包含的方法与属性:

    hash.update() 更新哈希对象所要计算的数据,多次调用为累加效果,如m.update(a);m.update(b)等价于m.update(a+b)
    hash.digest() 以二进制格式返回传递给update()函数的所有数据的摘要信息(字符串)
    hash.hexdigest() 以十六进制格式返回传递给update()函数的所有数据的摘要信息(字符串)
    hash.copy() 可用来有效计算共享一个初始子串的数据的摘要信息
    hash.digest_size hash结果的字节大小,即hash.digest()方法返回结果的字符串长度,MD5:16,sha1:20,sha224:28
    hash.block_size hash算法内部块的字节大小
    hash.name 当前hash对象对应的哈希算法的标准名称(小写形式),可以直接传递hashlib.new()函数来创建另外一个同类型的哈希对象

    实例:

    important

    import hashlib
    
    hash = hashlib.md5()
    hash.update(b'Hello, ')
    hash.update(b'World!')
    ret1 = hash.digest()     # 以二进制格式返回数据的加密信息
    print(type(ret1), len(ret1), ret1)
    ret2 = hash.hexdigest()    # 以十六进制返回加密的数据值
    print(type(ret2), len(ret2), ret2)

    result

    <class 'bytes'> 16 b'e\xa8\xe2}\x88y(81\xb6d\xbd\x8b\x7f\n\xd4'
    <class 'str'> 32 65a8e27d8879283831b664bd8b7f0ad4