.net-core - 如何在 .NET Core 中使用 256 位或更高位的 AES
问题描述
我有下面的代码,它适用于 128 位十六进制密钥。但是,当我提供 256 位十六进制密钥(或更高)时,它会引发错误
消息:System.ArgumentException:指定的密钥不是此算法的有效大小。参数名称:rgbKey
public static string Encrypt(string text, string keyString)
{
var key = Encoding.UTF8.GetBytes(keyString);
using (var aesAlg = Aes.Create())
{
using (var encryptor = aesAlg.CreateEncryptor(key, aesAlg.IV))
{
using (var msEncrypt = new MemoryStream())
{
using (var csEncrypt = new CryptoStream(msEncrypt, encryptor, CryptoStreamMode.Write))
using (var swEncrypt = new StreamWriter(csEncrypt))
{
swEncrypt.Write(text);
}
var iv = aesAlg.IV;
var decryptedContent = msEncrypt.ToArray();
var result = new byte[iv.Length + decryptedContent.Length];
Buffer.BlockCopy(iv, 0, result, 0, iv.Length);
Buffer.BlockCopy(decryptedContent, 0, result, iv.Length, decryptedContent.Length);
return Convert.ToBase64String(result);
}
}
}
}
如何使用 256 位或更高密钥的 AES?
解决方案
尝试将填充模式设置为 PKCS7。
aesAlg.Padding = PaddingMode.PKCS7。
推荐阅读
- python - 附加函数将元素添加到列表成员
- python - python中的“测试用例失败”是什么?
- go - 如何使用“golang.org/x/net/icmp”获取 icmp(ping) 目标 IP 地址
- microsoft-graph-api - 如何使用 Microsoft Graph 中的对话 ID 从线程中获取电子邮件内容(包括附件,如果有)?
- javascript - 如何根据结构中具有多个键的子值通过 Rest API 检索 Firebase 中的记录?
- mysql - 意外类型,期望名称
- python - 从电子邮件数据库列表中提取域
- c# - 如何在自定义 AuthenticationHandler 中自定义错误代码
- python - (猜数游戏 GUI)接收相同的结果
命令(Python/Tkinter) - clojure - 如何在 clojure/lisp 中获取“for”以仅返回值而不创建列表?