Python内置加密模块用法解析
作者:Vera_y 发布时间:2021-09-17 02:26:19
标签:python,内置,加密,模块
这篇文章主要介绍了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
注: 只要输入的内容和加密模式相同,则输出的密匙就相同
2.hmac模块
实现了HAMC算法,与hashlib提供的API基本一致
hamc模块提供的函数:
hamc.new(key,msg=None,digestmod=None) | 用于创建一个hmac对象,key为密钥,msg为初始数据,digestmod为所使用的哈希算法,默认为hashlib.md5 |
hmac.compare_digest(a,b) | 比较两个hmac对象,返回的是a==b的值 |
hamc对象中提供的方法与属性 与 hash对象中一致
实例:
improtant
import hmac
h1 = hmac.new(b'yeah', b'a', digestmod=hashlib.sha224) # digestmod 默认为MD5
h1.update(b'hello')
ret1 = h1.digest() # 二进制
ret2 = h1.hexdigest() # 十六进制
print(type(ret1), ret1)
print(type(ret2), ret2)
h2 = hmac.new(b'yeah', b'name')
ret3 = h2.hexdigest()
c = hmac.compare_digest(ret2, ret3) # 比较同类型进制的值
print(c)
result
<class 'bytes'> b'&\x9a\xd0{\x15WTE9@\xd9\xe3z\xfb+\\o\xc5\x88\x7f\x1c\xa4Q\xaf\x0c\n\xa8E'
<class 'str'> 269ad07b155754453940d9e37afb2b5c6fc5887f1ca451af0c0aa845
False
3.secrets模块
生成用于管理密码、账户验证信息、安全令牌和相关秘密信息等数据的密码强随机数
secrets模块的两种操作:
生成安全随机数
生成一个笃定长度的随机字符串(可用作令牌和安全URL)
secrets模块提供的函数:
secrets.choice(sequence) | 从指定的非空序列中随机选择一个元素并返回 |
secrets.randbelow(n) | 从半开区间[0,n]内随机返回一个整数 |
secrets.randbits(k) | 返回一个带有k个随机位的整数 |
secrets.token_bytes(nbytes=None) | 返回一个包含nbytes个字节的随机字符串 |
secrets.token_hex(nbytes=None) | 返回一个包含nbytes字节的16进制格式的随机文本字符串,可以用来生成一个随机密码 |
secrets.token_urlsafe([nbytes]) | 返回一个包含nbytes个字节的随机安全URL文本字符串,可以在提供重置密码的应用中用来生成一个临时的随机令牌 |
secrets.compare_digest(a,b) | 比较a,b字符串是否相等,若相等,返回True |
实例:
important
import secrets
a = range(0, 99)
s = secrets.choice(a)
b = secrets.randbelow(77)
print(s)
print(b)
print(secrets.randbits(k=6))
print(secrets.token_bytes(nbytes=2))
print(secrets.token_hex(nbytes=2))
print(secrets.token_urlsafe(2))
print(secrets.compare_digest('a', 'b')) # 比较'字符串'
result
32
b'op'
b248
LNI
False
来源:https://www.cnblogs.com/Vera-y/p/9706950.html
0
投稿
猜你喜欢
- 一、简单介绍pip 是 Python 包管理工具,该工具提供了对Python 包的查找、下载、安装和卸载的功能,现在大家用到的所有包不是自带
- 前言使用面向对象编程思想完成学员管理系统的开发,具体如下:系统要求:使用面向对象的方法系统功能:添加学员、删除学员、修改学员信息、查询学员信
- 在matplotlib下,一个Figure对象可以包含多个子图(Axes),可以使用subplot()快速绘制,其调用形式如下:subplo
- import 机制功能Python 的 import 机制基本上可以切分为三个不同的功能:Python运行时的全局模块池的维护和搜索;解析与
- 一般情况下,访问或设置剪贴板,IE 只需使用 window.clipboardData 的 getData 或 setData 方法即可。M
- 高级语言不能直接被机器所理解执行,所以都需要一个翻译的阶段,解释型语言用到的是解释器,编译型语言用到的是编译器。编译型语言通常的执行过程是:
- 译者 | 豌豆花下猫声明 :本文获得原作者授权翻译,转载请保留原文出处,请勿用于商业或非法用途。有许许多多文章写了 Python 中的许多很
- MyISAM 是MySQL中默认的存储引擎,一般来说不是有太多人关心这个东西。决定使用什么样的存储引擎是一个很tricky的事情,但是还是值
- Nextcloud 是一款自由 (开源) 的类 Dropbox 软件,由 ownCloud 分支演化形成。它使用 PHP 和 JavaScr
- 楔子pandas 支持我们从 Excel、CSV、数据库等不同数据源当中读取数据,来构建 DataFrame。但有时数据并不来自这些外部数据
- # django manage.py扩展自定义命令环境: mac django1.10.3在实际的项目开发过程中,我们可能要执行某脚本初始化
- 1.MySQL中并发和隔离控制机制Meta-data元数据锁:在table cache缓存里实现的,为DDL(Data Definition
- 接触编程的朋友都听过正则表达式,在python中叫re模块,属于文字处理服务里面的一个模块。re里面有一个方法叫match,接下来的文章我来
- Conda GuideConda简介conda是一个包,依赖和环境管理工具,适用于多种语言,如: Python, R, Scala, Jav
- <?php /** * Created by JetBrains Ph
- 用python的matplotlib画图时,往往需要加图例说明。如果不设置任何参数,默认是加到图像的内侧的最佳位置。import matpl
- 昨日晚平台升级,我们成功送BUG上线,今天系统问题又多了起来,大多数时候的运维问题需要根据业务反馈的#订单号# 查询到当前状态,然后再进行反
- 一、说明本文主要讲述采集猫眼电影用户评论进行分析,相关爬虫采集程序可以爬取多个电影评论。运行环境:Win10/Python3.5。分析工具:
- 很多互联网应用程序都提供了全文搜索功能,用户可以使用一个词或者词语片断作为查询项目来定位匹配的记录。在后台,这些程序使用在一个SELECT查
- 由于asp中是使用双引号作为字符串的开始和结束标志的,单一个字符串中的双引号出现次数大于两个时,程序就有可能运行错误。asp中是怎么输出引号