最近学习爬虫 遇到一些加密的坑 然后了解到了AES和RSA 记录一下
AES
1.什么是AES
AES是一种对称的加密算法,运行要求低,不需要计算机有非常高的处理能力和大的内存, 加密速度很快;
对称加密是最快速、最简单的一种加密方式,加密(encryption)与解密(decryption)用的是同样的密钥(secret key)。
2.AES特点
1.最常用的对称加密算法
2.密钥建立时间短、灵敏性好、内存需求低
3.AES加密方式有五种:ECB, CBC, CTR, CFB, OFB;实际使用中,使用工作模式为CTR(最好用CBC去实现),此工作模式需要引入IV参数(16位的字节数组)
4.密钥长度有三种 分别是128 192 256,最长只有256bit ,其中192与256需要配置无政策限制权限文件(JDK6)
5.填充模式最常用的两种PKCS5Padding和PKCS7Padding,其中后者只有CBC独有。
6.加密和解密用到的密钥是相同的,这种加密方式加密速度非常快,适合经常发送数据的场合。
加密流程图:
明文p : 没有经过加密的数据
密钥K:用来加密明文的密码,在对称加密算法中,加密的密钥和解密的密钥是相同的。密钥绝对不能泄露,否则会被获取还原密文,窃取数据
AES加密函数: 假设AES加密函数为A, 则C = A(K,P), 其中P为明文, K为密钥, C为密文,也就是说把明文和密钥作为加密函数的参数输入,就会加密为密文。
AES解密函数:假设AES解密函数为B, 则 P = B(K, C), 其中P为明文, K为密钥, C为密文,也就是说把密文和密钥作为解密函数的参数输入,就会解密还原回明文。
AES CBC加密解密样式代码:
Windows需要下载pycryptodome包 可以直接用pip install pycryptodome下载
from binascii import b2a_hex, a2b_hex from Crypto.Cipher import AES # 如果text不足16位的倍数就用空格补足为16位 def add_to_16(text): if len(text.encode('utf-8')) % 16: add = 16 - (len(text.encode('utf-8')) % 16) else: add = 0 text = text + ('