Python3+PyCryptodome实现各种加密算法教程 .pdfVIP

Python3+PyCryptodome实现各种加密算法教程 .pdf

  1. 1、本文档共5页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多

Python3+PyCryptodome实现各种加密算法教程

⼀、说明

PyCryptodome是python⼀个强⼤的加密算法库,可以实现常见的单向加密、对称加密、⾮对称加密和流加密算法。直接pip安装即可:

pipinstallpycryptodome

⼆、Base64编码

2.1base64编码说明

原理:

将要编码的内容按3字节为⼀组进⾏分组,最后⼀组不够3位的则补0(显然最多补两个0)

每组中每字节最⾼2位改成0不使⽤,原先各位的内容保持原有顺序往后移;最后在上⼀步中补了⼏个0就加⼏个等号以供解码时按等号个数

删除0(经此操作原先3节字就变成了只使⽤低6位的4字节)

⽤途:⼀是SMTP中要以BASE64形式传输⼆进制⽂件,⼆是常⽤于将⼆进制数据转成可打印的ASCII码字符进⾏存储(下⽂各加密算法的

密钥⼀般使⽤⼗六进制字符串形式存储,但也有以base64形式存储)。

其他:本质上讲Base64只能算是⼀种编码不能算是⼀种加密算法,PyCryptodome库也不⽀持。但从”Base64让⼈⼀下看不懂原本内容是什

么的“⾓度讲你也不能说他完全不算加密,平时也经常⽤,我们就顺道讲⼀讲如何实现。

2.2base64编码实现代码

importbase64

#编码b123456,输出为bMTIzNDU2

base64.b64encode(b123456)

#解码bMTIzNDU2,输出为b123456

base64.b64decode(bMTIzNDU2)

三、单向加密算法

3.1单向加密算法说明

别称:单向加密算法,⼜称哈希函数、散列函数、杂凑函数、摘要算法,英⽂名One-wayencryptionalgorithm。

原理:单向加密如其名只能加密不能解密(不是正经的解密),不能解密的原因是本质上并不是⽤IV(InitialVector)去加密M输出M的密

⽂,⽽是⽤M去加密IV输出IV的密⽂。

⽤途:消息认证摘要、内容或⽂档的数字指纹、⼝令存储。

其他:

单向加密⼜可以分为hash和hmac两⼤类,hmac和hash的算法是⼀样的,其实可以认为hmac就是hash加盐的形式(不过这盐值不是hash中

常⽤的拼接在最前边或拼接在最后边,具体怎么拼接的我不太确定)。

⼀般来说标准库就挺好⽤时我们⼀般就直接⽤标准库,python的标准库就能容易地实现单向加密算法,所以单向加密我们使⽤标准库实现。

python中hash类算法使⽤hashlib库实现,hmac类算法使⽤hmac库实现。

3.2标准库⽀持的单向加密算法

importhashlib

#注意输出结果中各算法使⽤⼤写和⼩写写了两遍

#同时也是说到后边的书写中算法名⼤写或⼩写都是可以的

hashlib.algorithms_available

3.3使⽤hashlib实现hash算法(以md5为例)

importhashlib

#实例化⽅法⼀,直接使⽤算法名;这种形式不完全⽀持hashlib.algorithms_available中的算法

#m=hashlib.md5()

#实例化⽅法⼆,使⽤new⽅法;所有⽀持的算法名看上边hashlib.algorithms_available

m=hashlib.new(md5)

#update内是要加密的内容

#update使⽤+=,即连续多次update表⽰在原先内容上追加⽽不是替换

m.update(b123456)

#以⼗六进制字符串形式输出

m.hexdigest()

3.4使⽤hmac实现hmac算法(以sha1为例)

importhmac

#实例化原形是hmac.new(key,msg=None,digestmod=None)

#key--加密⽤的盐值

#msg--要加密码的内容,可为空⽽后⽤update⽅法设置

#digestmod--加密算法,默认为md5,所有⽀持的算法名看上边hashlib.algorithms_available

m=hmac.new(b123,digestmod=sha1)

#update使⽤+=,即连续多次update表⽰在原先内容上追加⽽不是替换

#但要注意所谓的+=是msg之间的+=,⽽不是key和msg之间的+=

#即使⽤以下update后等于hmac.new(b123,b123456,digestmod=sha1),但不等于hmac.new(b

文档评论(0)

132****5766 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档