• Aes_ECB+bash64 加密


    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=='))
    

      

  • 相关阅读:
    本地搭建Nginx服务器启动web项目
    BZOJ 1815: [Shoi2006]color 有色图(Polya定理)
    即将退役选手最后的挣扎
    类欧几里得算法
    UOJ#449. 【集训队作业2018】喂鸽子(期望dp)
    Luogu P3600 随机数生成器(期望+dp)
    毒题选讲选做
    UOJ#310.【UNR #2】黎明前的巧克力(FWT)
    DZY Loves Math 系列详细题解
    项目中经常遇到的跨域请求的几种方法
  • 原文地址:https://www.cnblogs.com/yoyo1216/p/12568927.html
Copyright © 2020-2023  润新知