Aes_ECB+bash64 加密
import base64
from Crypto.Cipher import AES
from Crypto.Random import get_random_bytes
from Crypto import Random
import binascii
class Aes_ECB(object):
def __init__(self, key):
self.key = key
self.MODE = AES.MODE_ECB
self.BS = AES.block_size
self.pad = lambda s: s + (self.BS - len(s) % self.BS) * chr(self.BS - len(s) % self.BS)
self.unpad = lambda s: s[0:-ord(s[-1])]
# str不是16的倍数那就补足为16的倍数
def add_to_16(value):
while len(value) % 16 != 0:
value += ' '
return str.encode(value) # 返回bytes
def AES_encrypt(self, text):
aes = AES.new(Aes_ECB.add_to_16(self.key), self.MODE) # 初始化加密器
encrypted_text = str(base64.encodebytes(aes.encrypt(Aes_ECB.add_to_16(self.pad(text)))),
encoding='utf-8').replace('
', '') # 这个replace大家可以先不用,然后在调试出来的结果中看是否有'
'换行符
# 执行加密并转码返回bytes
return encrypted_text
def AES_encrypts(self, text):
aes = AES.new(Aes_ECB.add_to_16(self.key), self.MODE) # 初始化加密器
encrypted_text = aes.encrypt(Aes_ECB.add_to_16(self.pad(text))) # 这个replace大家可以先不用,然后在调试出来的结果中看是否有'
'换行符
print(encrypted_text)
print(encrypted_text.hex())
# 执行加密并转码返回bytes
return encrypted_text
# 解密
def AES_decrypt(self, text):
# 初始化加密器
aes = AES.new(Aes_ECB.add_to_16(self.key), self.MODE)
# 优先逆向解密base64成bytes
base64_decrypted = base64.decodebytes(text.encode(encoding='utf-8'))
decrypted_text = self.unpad(aes.decrypt(base64_decrypted).decode('utf-8'))
decrypted_code = decrypted_text.rstrip(' ')
return decrypted_code
if __name__ == '__main__':
aces = Aes_ECB('b496faa50eea2fb60cf01283609b69b4')
print(aces.AES_encrypts('abc#123'))
# print(aces.AES_decrypt('PvPEZdXQOi4jA2g4xesbxw=='))