Я должен расшифровать уже зашифрованные значения. Я знаю используемые настройки, ключ и iv, но продолжаю получать неправильные результаты. Я знаю, что шифрование выполняется так же, как этот онлайн-инструмент - https://appzaza.com/encrypt-text, который дает правильные результаты, но не может найти причину, по которой мой вывод отличается.
Настройки:
Режим: 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;
}
Я пробовал все разные режимы заполнения, но безрезультатно