AES加密错误:输入数据不是完整的块?

时间:2013-10-27 03:04:09

标签: c# encryption

这是加密方法:

public static byte[] Encrypt(byte[] plaintext, byte[] key)
{
    using (var aes = Aes.Create())
    {
        aes.BlockSize = 128;
        aes.Mode = CipherMode.ECB;
        aes.Padding = PaddingMode.None;

        var iv = new byte[16];
        for (int i = 0; i < iv.Length; i++)
            iv[i] = 0;
        aes.IV = iv;

        var encryptor = aes.CreateEncryptor(key, aes.IV);
        using(var target = new MemoryStream())
        using (var cs = new CryptoStream(target, encryptor, CryptoStreamMode.Write))
        {
            using (var source = new StreamWriter(cs))
                source.Write(plaintext);
            return target.ToArray();
        }
    }
}

我是怎么称呼的:

var key = new byte[16] { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 };
var plaintext = new byte[16] { 128, 0, 112, 0, 96, 0, 80, 0, 64, 0, 48, 0, 32, 0, 16, 0 };

但它一直在source.Write(明文)上抛出异常,说它不是一个完整的块?我正在使用16字节/ 128位阵列,块大小设置为128.我不明白什么是错的?

另外,只是为了阻止任何有关ECB不好等的建议,这不是为了生产,我只是在玩耍。

4 个答案:

答案 0 :(得分:7)

StreamWriter将UTF8文本字符写入流中 您正在编写plaintext.ToString()作为密文的文本。

这将返回"System.Byte[]",它不会转换为16字节的UTF8。

答案 1 :(得分:3)

我认为问题是填充模式。除非您要加密的文本确实可被BlockSize整除(以位或BlockSize / 8为单位),否则应指定除None之外的PaddingMode。

请参阅post here示例代码

答案 2 :(得分:0)

我将功能更改为:

public static byte[] Encrypt(byte[] plaintext, byte[] key)
{
    using (var aes = Aes.Create())
    {
        aes.BlockSize = 128;
        aes.Mode = CipherMode.ECB;
        aes.Padding = PaddingMode.None;

        var encryptor = aes.CreateEncryptor(key, new byte[16]);
        using(var target = new MemoryStream())
        using (var cs = new CryptoStream(target, encryptor, CryptoStreamMode.Write))
        {
            cs.Write(plaintext, 0, plaintext.Length);
            return target.ToArray();
        }
    }
}

答案 3 :(得分:0)

如果不使用-key选项对密码进行加密,则可能会发生这种情况。要修复它,请使用-key选项对其加密: ConvertFrom-SecureString -key $ key