У меня есть код ниже, который работает с 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);
}
}
}
}
Как использовать AES с ключом 256 бит или выше?