这是加密方法:
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不好等的建议,这不是为了生产,我只是在玩耍。
答案 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