Как использовать AES с 256 бит или выше в .NET Core - PullRequest
0 голосов
/ 26 сентября 2018

У меня есть код ниже, который работает с 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 бит или выше?

1 Ответ

0 голосов
/ 27 сентября 2018

Попробуйте установить режим заполнения на PKCS7.

aesAlg.Padding = PaddingMode.PKCS7.

...