8

加密方法如下:

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(plaintext) 抛出一个异常,说它不是一个完整的块?我正在使用块大小设置为 128 的 16 字节/128 位数组。我不明白有什么问题?

另外,只是为了阻止任何关于欧洲央行不好等的建议,这不是为了生产,我只是在玩。

4

5 回答 5

11

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

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

于 2013-10-27T03:12:54.387 回答
7

我认为问题出在填充模式上。除非您要加密的文本确实可以被 BlockSize 整除(以位为单位,或 BlockSize / 8 以字节为单位),否则您应该指定一个 PaddingMode 而不是 None。

有关示例代码,请参见此处的帖子

于 2016-03-24T18:58:20.497 回答
2

我将功能更改为:

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();
        }
    }
}
于 2013-10-27T03:37:28.827 回答
0

根据我所经历和解决的这个问题,我错过了加密它抱怨的字段,我只是在解密它。它正在保存一个纯明文并试图解密它。因此,请确保首先对抱怨的字段进行加密。谢谢

于 2022-02-07T14:53:33.350 回答
-6

这对 PowerShell 有效:如果您在不使用 -key 选项的情况下加密了密码,则可能会发生这种情况。要修复它,请使用 -key 选项对其进行加密:

ConvertFrom-SecureString -key $key
于 2020-09-22T20:17:37.900 回答