AES解密输入的数据不是完整的块

mys*_*ick 0 c# encryption aes

我正在尝试加密string并使用解密AES。加密工作正常,但The input data is not a complete block解密出现错误。我的填充物有问题吗?

var aes = System.Security.Cryptography.Aes.Create();
aes.GenerateKey();
aes.GenerateIV();
aes.Mode = CipherMode.CBC;
aes.Padding = PaddingMode.PKCS7;

var desEncrypter = aes.CreateEncryptor();
var buffer = System.Text.ASCIIEncoding.ASCII.GetBytes(text);

finalV = Convert.ToBase64String(desEncrypter.TransformFinalBlock(buffer, 0, buffer.Length));

var desDecrypter = aes.CreateDecryptor();
var buff = System.Text.Encoding.ASCII.GetBytes(finalV);

var origValue = desDecrypter.TransformFinalBlock(buff , 0, buff .Length);
Run Code Online (Sandbox Code Playgroud)

Joe*_*nos 5

您是finalV通过将字节转换为Base64 来创建的。为了将其转换为字节,您需要调用Convert.FromBase64String(finalV)

您正在调用ASCII.GetBytes(finalV),它将获取代表该Base64文本的字节,而不是原始字节。

编辑

不知道您在哪里卡住了,但是这里是基于您的代码的有效代码,因此您可以对此进行区分并查看错误的出处:

string text = "ABC";

var aes = System.Security.Cryptography.Aes.Create();
aes.GenerateKey();
aes.GenerateIV();
aes.Mode = CipherMode.CBC;
aes.Padding = PaddingMode.PKCS7;

var desEncrypter = aes.CreateEncryptor();
var buffer = System.Text.ASCIIEncoding.ASCII.GetBytes(text);

var finalV = Convert.ToBase64String(desEncrypter.TransformFinalBlock(buffer, 0, buffer.Length));

var desDecrypter = aes.CreateDecryptor();
var buff = Convert.FromBase64String(finalV);

var origValue = desDecrypter.TransformFinalBlock(buff, 0, buff.Length);
string result = Encoding.ASCII.GetString(origValue);
Console.WriteLine(result);
Run Code Online (Sandbox Code Playgroud)