.net core 如何在.NET内核中使用256位或更高的AES

.net core 如何在.NET内核中使用256位或更高的AES,.net-core,cryptography,aes,asp.net-core-2.0,coreclr,.net Core,Cryptography,Aes,Asp.net Core 2.0,Coreclr,我有下面的代码,它使用128位十六进制键。但是,当我提供256位十六进制键(或更高)时,它会抛出错误 消息:System.ArgumentException:指定的密钥大小无效 对于这个算法。参数名称:rgbKey 如何使用256位或更高密钥的AES?尝试将填充模式设置为PKCS7 aesAlg.Padding=PaddingMode.PKCS7。AES只接受128、192或256位的密钥。如果您有一个十六进制编码的密钥,则必须首先对其应用十六进制解码器。使用UTF8.GetBytes()不是十

我有下面的代码,它使用128位十六进制键。但是,当我提供256位十六进制键(或更高)时,它会抛出错误

消息:System.ArgumentException:指定的密钥大小无效 对于这个算法。参数名称:rgbKey


如何使用256位或更高密钥的AES?

尝试将填充模式设置为PKCS7


aesAlg.Padding=PaddingMode.PKCS7。

AES只接受128、192或256位的密钥。如果您有一个十六进制编码的密钥,则必须首先对其应用十六进制解码器。使用UTF8.GetBytes()不是十六进制解码。我用来生成128位十六进制密钥。。我试试256位。。我得到了例外啊,我的坏消息。你说这是个十六进制键。您需要对其进行解码,然后将其传递给createencryptor方法。
        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);
                    }
                }
            }
        }