Python中常见的加密解密算法有哪些
时间:2023-05-17 03:18
简介:当url地址含有中文,或者参数有中文的时候,这个算是很正常了,但是把这样的url作为参数传递的时候(最常见的callback),需要把一些中文甚至'/'做一下编码转换。 其实这应该不算一种加密 更多的应该算是一种编码与解码,但是由于运用很广泛 我也加进去了 简介:Base64 是一种用 64 个字符来表示任意二进制数据的方法。 简介:全称 MD5 消息摘要算法(英文名称:MD5 Message-Digest Algorithm),又称哈希算法、散列算法,由美国密码学家罗纳德·李维斯特(Ronald Linn Rivest)设计,于 1992 年作为 RFC 1321 被公布,用以取代 MD4 算法。摘要算法属于单向加密,这意味着用摘要算法处理后的明文无法被解密。 摘要算法的第二个特点密文是固定长度的,它通过一个函数,把任意长度的数据转换为一个长度固定的数据串(通常用16进制的字符串表示)。之所以叫摘要算法,它的算法就是提取明文重要的特征。使用摘要算法后,两个不同的明文可能会生成相同的密文,但这种情况非常罕见。 简介:英文名称:Password-Based Key Derivation Function 2,PBKDF2 是 RSA 实验室的公钥加密标准(PKCS)系列的一部分, PBKDF2 将伪随机函数(例如 HMAC),把明文和一个盐值(salt)作为输入参数,然后进行重复运算,并最终产生密钥,如果重复的次数足够大,破解的成本就会变得很高。 简介:全称安全哈希算法(英文名称:Secure Hash Algorithm),主要适用于数字签名标准(Digital Signature Standard DSS)里面定义的数字签名算法( 简介:全称散列消息认证码、密钥相关的哈希运算消息认证码(英文名称:Hash-based Message Authentication Code 或者 Keyed-hash Message Authentication Code),于 1996 年提出,1997 年作为 RFC 2104 被公布,HMAC 加密算法是一种安全的基于加密 Hash函数和共享密钥的消息认证协议,它要求通信双方共享密钥 key、约定算法、对报文进行 Hash 运算,形成固定长度的认证码。通信双方通过认证码的校验来确定报文的合法性。 简介:全称数据加密标准(英文名称:Data Encryption Standard),加密与解密使用同一密钥,属于对称加密算法,1977 年被美国联邦政府的国家标准局确定为联邦资料处理标准(FIPS),DES 是一个分组加密算法,使用 56 位的密钥(一般认为密钥是 64 位,但是密钥的每个第 8 位设置为奇偶校验位,所以实际上有效位只有 56 位),由于 56 位密钥长度相对较短,所以 DES 是不安全的,现在基本上已被更高级的加密标准 AES 取代。 mode 支持:CBC,CFB,CTR,CTRGladman,ECB,OFB 等。 padding 支持:ZeroPadding,NoPadding,AnsiX923,Iso10126,Iso97971,Pkcs7 等。 简介:全称三重数据加密算法(英文名称:Triple Data Encryption Standard、Triple Data Encryption Algorithm、TDES、TDEA),是对称加密算法中的一种。70 年代初由 IBM 研发,后 1977 年被采纳为数据加密标准,它相当于是对每个数据块应用三次 DES 加密算法。由于计算机运算能力的增强,原版 DES 密码的密钥长度变得容易被暴力破解;3DES 即是设计用来提供一种相对简单的方法,即通过增加 DES 的密钥长度来避免破解,所以严格来说 3DES 不是设计一种全新的块密码算法。 mode 支持:CBC,CFB,CTR,CTRGladman,ECB,OFB 等。 padding 支持:ZeroPadding,NoPadding,AnsiX923,Iso10126,Iso97971,Pkcs7 等。1.url encode加密
# -*- coding: utf-8 -*-# @Time : 2022/9/29 10:43# @Author : lzc# @Email : hybpjx@163.com# @File : utilsMiddlewares.py# @cnblogs : https://www.cnblogs.com/zichliang/# @Software: PyCharm import urllib.parse text = "我爱吃鸡腿"s = urllib.parse.quote(text)print(s) # %E6%88%91%E7%88%B1%E5%90%83%E9%B8%A1%E8%85%BFu = urllib.parse.unquote(s)print(u) #我爱吃鸡腿
2.unicode 加密
# -*- coding: utf-8 -*-# @Time : 2023/2/28 10:43# @Author : lzc# @Email : hybpjx@163.com# @File : utilsMiddlewares.py# @cnblogs : https://www.cnblogs.com/zichliang/# @Software: PyCharm str1 = "你好" # 编码enStr1 = str1.encode('unicode-escape').decode()print(enStr1) # u4f60u597d # 解码deStr1 = enStr1.encode().decode('unicode-escape')print(deStr1) # 你好
3.Base64 加密
# -*- coding: utf-8 -*-# @Time : 2022/9/29 10:43# @Author : lzc# @Email : hybpjx@163.com# @File : utilsMiddlewares.py# @cnblogs : https://www.cnblogs.com/zichliang/# @Software: PyCharm import base64 def base64_encode(text): encode_data = base64.b64encode(text.encode()) return encode_data def base64_decode(encode_data): decode_data = base64.b64decode(encode_data) return decode_data if __name__ == '__main__': text = 'I love Python!' encode_data = base64_encode(text) decode_data = base64_decode(encode_data) print('Base64 编码:', encode_data) print('Base64 解码:', decode_data) # Base64 编码: b'SSBsb3ZlIFB5dGhvbiE='# Base64 解码: b'I love Python!'
4.MD5
# -*- coding: utf-8 -*-# @Time : 2022/9/29 10:43# @Author : lzc# @Email : hybpjx@163.com# @File : utilsMiddlewares.py# @cnblogs : https://www.cnblogs.com/zichliang/# @Software: PyCharm import hashlib def md5_test1(): md5 = hashlib.new('md5', 'I love python!'.encode('utf-8')) print(md5.hexdigest()) def md5_test2(): md5 = hashlib.md5() md5.update('I love '.encode('utf-8')) md5.update('python!'.encode('utf-8')) print(md5.hexdigest()) if __name__ == '__main__': md5_test1() # 21169ee3acd4a24e1fcb4322cfd9a2b8 md5_test2() # 21169ee3acd4a24e1fcb4322cfd9a2b8
5.PBKDF2
2017 年发布的 RFC 8018 (PKCS #5 v2.1)推荐使用 PBKDF2 进行密码散列。# -*- coding: utf-8 -*-# @Time : 2022/9/29 10:43# @Author : lzc# @Email : hybpjx@163.com# @File : utilsMiddlewares.py# @cnblogs : https://www.cnblogs.com/zichliang/# @Software: PyCharm import binasciifrom Cryptodome.Hash import SHA1from Cryptodome.Protocol.KDF import PBKDF2 text = 'I love Python!'salt = b'43215678'result = PBKDF2(text, salt, count=10, hmac_hash_module=SHA1)result = binascii.hexlify(result)print(result)# b'7fee6e8350cfe96314c76aaa6e853a50'
6.SHA
Digital Signature Algorithm DSA),SHA 通常指 SHA 家族的五个算法,分别是 SHA-1、SHA-224、SHA-256、SHA-384、SHA-512,后四者有时并称为 SHA-2,SHA 是比 MD5 更安全一点的摘要算法,MD5 的密文是 32 位,而 SHA-1 是 40 位,版本越强,密文越长,代价是速度越慢。# -*- coding: utf-8 -*-# @Time : 2022/9/29 10:43# @Author : lzc# @Email : hybpjx@163.com# @File : utilsMiddlewares.py# @cnblogs : https://www.cnblogs.com/zichliang/# @Software: PyCharm import hashlib def sha1_test1(): sha1 = hashlib.new('sha1', 'I love python!'.encode('utf-8')) print(sha1.hexdigest()) def sha1_test2(): sha1 = hashlib.sha1() sha1.update('I love python!'.encode('utf-8')) print(sha1.hexdigest()) if __name__ == '__main__': sha1_test1() # 23c02b203bd2e2ca19da911f1d270a06d86719fb sha1_test2() # 23c02b203bd2e2ca19da911f1d270a06d86719fb
7.HMAC
import hmac# -*- coding: utf-8 -*-# @Time : 2022/9/29 10:43# @Author : lzc# @Email : hybpjx@163.com# @File : utilsMiddlewares.py# @cnblogs : https://www.cnblogs.com/zichliang/# @Software: PyCharm def hmac_test1(): message = b'I love python!' key = b'secret' md5 = hmac.new(key, message, digestmod='MD5') print(md5.hexdigest()) def hmac_test2(): key = 'secret'.encode('utf8') sha1 = hmac.new(key, digestmod='sha1') sha1.update('I love '.encode('utf8')) sha1.update('Python!'.encode('utf8')) print(sha1.hexdigest()) if __name__ == '__main__': hmac_test1() # 9c503a1f852edcc3526ea56976c38edf hmac_test2() # 2d8449a4292d4bbeed99ce9ea570880d6e19b61a
8.DES
# -*- coding: utf-8 -*-# @Time : 2022/9/29 10:43# @Author : lzc# @Email : hybpjx@163.com# @File : utilsMiddlewares.py# @cnblogs : https://www.cnblogs.com/zichliang/# @Software: PyCharm import binascii# 加密模式 CBC,填充方式 PAD_PKCS5from pyDes import des, CBC, PAD_PKCS5 def des_encrypt(key, text, iv): k = des(key, CBC, iv, pad=None, padmode=PAD_PKCS5) en = k.encrypt(text, padmode=PAD_PKCS5) return binascii.b2a_hex(en) def des_decrypt(key, text, iv): k = des(key, CBC, iv, pad=None, padmode=PAD_PKCS5) de = k.decrypt(binascii.a2b_hex(text), padmode=PAD_PKCS5) return de if __name__ == '__main__': secret_key = '12345678' # 密钥 text = 'I love Python!' # 加密对象 iv = secret_key # 偏移量 secret_str = des_encrypt(secret_key, text, iv) print('加密字符串:', secret_str) clear_str = des_decrypt(secret_key, secret_str, iv) print('解密字符串:', clear_str) # 加密字符串: b'302d3abf2421169239f829b38a9545f1' # 解密字符串: b'I love Python!'
9.3DES
# -*- coding: utf-8 -*-# @Time : 2022/9/29 10:43# @Author : lzc# @Email : hybpjx@163.com# @File : utilsMiddlewares.py# @cnblogs : https://www.cnblogs.com/zichliang/# @Software: PyCharm from Cryptodome.Cipher import DES3from Cryptodome import Random # 需要补位,str不是16的倍数那就补足为16的倍数def add_to_16(value): while len(value) % 16 != 0: value += '