python3 常见解密加密算法实例分析【base64、MD5等】
本文实例讲述了python3 常见解密加密算法。分享给大家供大家参考,具体如下:
一.使用base64
Base64编码,64指A-Z、a-z、0-9、+和/这64个字符,还有“=”号不属于编码字符,而是填充字符。
优点:方法简单
缺点:不保险,别人拿到密文可以自己解密出明文
编码原理:将3个字节转换成4个字节((3 X 8)=24=(4X6)),先读入3个字节,每读一个字节,左移8位,再右移四次,每次6位,这样就有4个字节了。
解码原理:将4个字节转换成3个字节,先读入4个6位(用或运算),每次左移6位,再右移3次,每次8位,这样就还原了。
Python3中base64模块与Python2使用方法有了明显的不一样,接下来简要介绍下base64模块。
Python 3.5.2+ (default, Aug 5 2016, 08:07:14)
[GCC 6.1.1 20160724] on linux
Type "help", "copyright", "credits" or "license" for more information.
首先导入base64模块
>>> import base64 >>> my_str='hello'
然后把字符串转码为UTF-8格式:
>>> utf_str=my_str.encode(encoding="utf-8") >>> utf_str b'hello'
我们试着用Base64方式加密:
>>> word=base64.b64encode(utf_str) >>> word b'aGVsbG8='
最后用Base64方式解密:
>>> hello=base64.b64decode(word.decode()) >>> hello b'hello' >>> hello.decode() 'hello'
可以看到,已经成功解密出来!
二.使用pycrypto
Python有个专门的加密解密工具包pycropto,这个包里面实现了MD2,MD4,MD5,RIPEMD,SHA1,SHA256等加密算法。
>>> from Crypto.Hash import MD5 >>> obj = MD5.new() >>> obj.update(b"hello") >>> obj.hexdigest() >>> obj.hexdigest() '5d41402abc4b2a76b9719d911017c592'
PS:关于加密解密感兴趣的朋友还可以参考本站在线工具:
文字在线加密解密工具(包含AES、DES、RC4等):
http://tools.jb51.net/password/txt_encode
MD5在线加密工具:
http://tools.jb51.net/password/CreateMD5Password
在线散列/哈希算法加密工具:
http://tools.jb51.net/password/hash_encrypt
在线MD5/hash/SHA-1/SHA-2/SHA-256/SHA-512/SHA-3/RIPEMD-160加密工具:
http://tools.jb51.net/password/hash_md5_sha
在线sha1/sha224/sha256/sha384/sha512加密工具:
http://tools.jb51.net/password/sha_encode
更多关于Python相关内容感兴趣的读者可查看本站专题:《Python加密解密算法与技巧总结》、《Python编码操作技巧总结》、《Python文件与目录操作技巧汇总》、《Python数据结构与算法教程》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》及《Python入门与进阶经典教程》
希望本文所述对大家Python程序设计有所帮助。
相关文章
pandas分组聚合(agg,transform,apply)
在SQL中我们经常使用 GROUP BY 将某个字段,按不同的取值进行分组, 在pandas中也有groupby函数,本文主要介绍了pandas分组聚合(agg,transform,apply),具有一定的参考价值,感兴趣的可以了解一下2024-04-04Jmeter通过OS进程取样器调用Python脚本实现参数互传
这篇文章主要介绍了Jmeter通过OS进程取样器调用Python脚本实现参数互传,描述在cmd中调用上面的Python脚本并传入两个参数展开主题,具有一定的参考价值,需要的小伙伴可以参考一下2022-03-03
最新评论