ValueError: Data must be aligned to block boundary in ECB mode

 

 指的是 : data 数据长度要是这个 block  length 的倍数

 解决方法:

    
class EncryptData():
    def __init__(self,key):
        self.key = key
        self.lenth = DES.block_size    # 加密数据的长度
        self.dec = DES.new(key,DES.MODE_ECB)   # 创建DES实例




    def add_8(self,info):
        while len(info)% self.lenth != 0:
            info += b'\x00'       #   '\x00' 值得是空格占位符
        return info

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
出现"ValueError: Data must be aligned to block boundary in ECB mode"的原因是在使用AES ECB模式时,数据长度不是16的倍数。这个错误可以通过增加填充来解决。 在这里,我们可以使用PKCS7填充,将数据长度填充到16的倍数。修改后的代码如下: ```python from Crypto.Cipher import AES import os # PKCS7填充 def pkcs7_padding(data): padding_len = AES.block_size - len(data) % AES.block_size padding = bytes([padding_len] * padding_len) return data + padding # PKCS7反填充 def pkcs7_unpadding(data): padding_len = data[-1] return data[:-padding_len] # 生成随机子密钥 def generate_subkey(key): aes = AES.new(key, AES.MODE_ECB) subkey = os.urandom(16) return aes.encrypt(subkey) # 加密函数 def encrypt(key, plaintext): aes = AES.new(key, AES.MODE_ECB) plaintext = pkcs7_padding(plaintext) ciphertext = aes.encrypt(plaintext) subkey = generate_subkey(key) aes = AES.new(subkey, AES.MODE_ECB) encrypted_subkey = aes.encrypt(subkey) return encrypted_subkey + ciphertext # 解密函数 def decrypt(key, ciphertext): encrypted_subkey = ciphertext[:16] subkey = AES.new(key, AES.MODE_ECB).decrypt(encrypted_subkey) aes = AES.new(subkey, AES.MODE_ECB) plaintext = aes.decrypt(ciphertext[16:]) plaintext = pkcs7_unpadding(plaintext) return plaintext # 测试代码 if __name__ == '__main__': key = os.urandom(16) plaintext = b'This is a test plaintext.' ciphertext = encrypt(key, plaintext) decrypted_plaintext = decrypt(key, ciphertext) print(decrypted_plaintext) ``` 在修改后的代码中,我们增加了PKCS7填充和反填充函数,用于将数据长度填充到16的倍数。在加密函数中,我们首先对明文进行填充,然后再进行加密。在解密函数中,我们先使用给定的密钥解密出加密后的子密钥,然后使用该子密钥解密密文,最后再进行反填充,得到明文。 需要注意的是,在使用PKCS7填充时,如果数据长度已经是16的倍数,还需要增加一个16字节的填充块。此外,在使用填充时,需要确保加密和解密的代码中都使用了相同的填充方式。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

allen wy

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值