import base64 from Crypto.Cipher import AES import random import string # 采用AES对称加密算法,CBC iv=b'0000100010010010' # str不是16的倍数那就补足为16的倍数 def add_to_16(value):#填充 if isinstance(value,bytes): value.decode() while len(value) % 16 != 0: value += '\0' return str.encode(value) # 返回bytes #加密方法 def AesEncrypt(data,key):#AES加密 if isinstance(data,bytes): text=base64.b64encode(data).decode('ascii') else: text = base64.b64encode(data.encode('utf-8')).decode('ascii') # 初始化加密器 aes = AES.new(add_to_16(key), AES.MODE_CBC,IV=iv) #先进行aes加密 encrypt_aes = aes.encrypt(add_to_16(text)) #用base64转成字符串形式 encrypted_text = str(base64.encodebytes(encrypt_aes), encoding='utf-8') # 执行加密并转码返回bytes return encrypted_text #解密方法 def AesDecrypt(text,key):#AES解密 # 初始化加密器 aes = AES.new(add_to_16(key), AES.MODE_CBC,IV=iv) #优先逆向解密base64成bytes if isinstance(text,str): base64_decrypted = base64.decodebytes(text.encode(encoding='utf-8')) else: base64_decrypted=base64.decodebytes(text) decrypted_text = str(aes.decrypt(base64_decrypted),encoding='utf-8') # 执行解密密并转码返回str decrypted_text = base64.b64decode(decrypted_text.encode('utf-8'))\ # .decode('utf-8') return decrypted_text def genKey():#生成密钥 source=string.ascii_letters+string.digits key="".join(random.sample(source,16)) return key if __name__ == '__main__': text='你好你好' mykey=genKey() print("加密密钥是"+mykey) e=AesEncrypt(text,mykey) d=AesDecrypt(e,mykey) print(e) print(d)