Отличный вывод от реализаций AES-256-CFB - PullRequest
0 голосов
/ 06 июля 2018

Я должен расшифровать уже зашифрованные значения. Я знаю используемые настройки, ключ и iv, но продолжаю получать неправильные результаты. Я знаю, что шифрование выполняется так же, как этот онлайн-инструмент - https://appzaza.com/encrypt-text, который дает правильные результаты, но не может найти причину, по которой мой вывод отличается. enter image description here

Настройки: Режим: CFB KeySize: 256 Кодировка: UTF-8

Мой код:

            static void Main()
            {
                string plaintext = "1515151515115129";
                string pass = "ncJ9JhWrXa9DqN1GzBCNlBoKs289Q1dD";
                string iveee = "jHGasOT60bJXcHdd";
                string message = "sdH9HhaLd8K8f0jBdOP/2g==";

                byte[] passBytes = (Encoding.UTF8.GetBytes(pass));

                // Create secret IV
                byte[] ivBytes = Encoding.UTF8.GetBytes(iveee);

                string decrypted = DecryptString(message, passBytes, ivBytes);
            }

            public static string DecryptString(string cipherText, byte[] key, byte[] iv)
            {
                // Instantiate a new Aes object to perform string symmetric encryption
                //Aes encryptor = Aes.Create();
                using (var encryptor = Aes.Create())
                {
                    encryptor.Mode = CipherMode.CFB;
                    encryptor.KeySize = 256;
                    encryptor.Padding = PaddingMode.Zeros;

                    // Set key and IV
                    encryptor.Key = key;
                    encryptor.IV = iv;

                    byte[] cipherBytes = Convert.FromBase64String(cipherText);

                    // Instantiate a new MemoryStream object to contain the encrypted bytes
                    using (MemoryStream memoryStream = new MemoryStream(cipherBytes))
                    {

                        // Instantiate a new encryptor from our Aes object
                        using (ICryptoTransform aesDecryptor = encryptor.CreateDecryptor(key, iv))
                        {
                            string plainText = "";
                            // Instantiate a new CryptoStream object to process the data and write it to the 
                            // memory stream
                            using (CryptoStream cryptoStream = new CryptoStream(memoryStream, aesDecryptor, CryptoStreamMode.Read))
                            {
                                using (StreamReader sr = new StreamReader(cryptoStream))
                                {
                                    plainText = sr.ReadToEnd();
                                }
                            }
                            return plainText;
                        }
                    }
                }
            }

Есть идеи, в чем может быть причина?

Ввод кода шифрования, который я использую для тестирования:

        public static string EncryptString(string plainText, byte[] key, byte[] iv)
        {
            // Instantiate a new Aes object to perform string symmetric encryption
            Aes encryptor = Aes.Create();

            encryptor.Mode = CipherMode.CFB;
            encryptor.KeySize = 256;
            encryptor.Padding = PaddingMode.Zeros;

            // Set key and IV
            encryptor.Key = key;
            encryptor.IV = iv;

            // Instantiate a new MemoryStream object to contain the encrypted bytes
            MemoryStream memoryStream = new MemoryStream();

            // Instantiate a new encryptor from our Aes object
            ICryptoTransform aesEncryptor = encryptor.CreateEncryptor();

            // Instantiate a new CryptoStream object to process the data and write it to the 
            // memory stream
            CryptoStream cryptoStream = new CryptoStream(memoryStream, aesEncryptor, CryptoStreamMode.Write);

            // Convert the plainText string into a byte array
            byte[] plainBytes = Encoding.UTF8.GetBytes(plainText);

            // Encrypt the input plaintext string
            cryptoStream.Write(plainBytes, 0, plainBytes.Length);

            // Complete the encryption process
            cryptoStream.FlushFinalBlock();

            // Convert the encrypted data from a MemoryStream to a byte array
            byte[] cipherBytes = memoryStream.ToArray();

            // Close both the MemoryStream and the CryptoStream
            memoryStream.Close();
            cryptoStream.Close();

            // Convert the encrypted byte array to a base64 encoded string
            string cipherText = Convert.ToBase64String(cipherBytes, 0, cipherBytes.Length);

            // Return the encrypted data as a string
            return cipherText;
        }

Я пробовал все разные режимы заполнения, но безрезультатно

...