zoukankan      html  css  js  c++  java
  • python3 AES.MODE_ECB(128位) pkcs5padding 加密算法

    一.错误信息

    TypeError("Object type %s cannot be passed to C code" % type(data))

    二.代码

    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_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
    
  • 相关阅读:
    【转】Linq Group by
    SmtpClient发邮件时为什么用MailMessage.From而不用MailMessage.Sender
    HttpClient异步调用WEB服务
    WPF MVVM框架下,VM界面写控件
    WPF 后台读取样式文件
    vs2017 乱码
    ClickOnce 和管理员权限
    EF code first Mysql 更换主键类型
    Linq Group By
    Mvc api HelpPage 与注释
  • 原文地址:https://www.cnblogs.com/gqv2009/p/12363138.html
Copyright © 2011-2022 走看看