首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >AES解密输入数据不是一个完整的块

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

Stack Overflow用户
提问于 2017-02-03 19:49:20
回答 1查看 7.1K关注 0票数 2

我试图加密一个string并使用AES解码它。加密工作正常,但我得到了一个The input data is not a complete block的解密错误。我的垫子有问题吗?

代码语言:javascript
运行
复制
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);
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-02-03 19:52:13

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

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

编辑

不知道您被困在了哪里,但是下面是基于您的代码的工作代码,因此您可以将其区分开来,看看您在哪里得到了错误:

代码语言:javascript
运行
复制
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);
票数 7
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/42031968

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档