Длина данных для расшифровки неверна - PullRequest
0 голосов
/ 30 марта 2012

Я исследовал проблему, возникающую при попытке расшифровки с помощью библиотек Rijndael C #.Я пробовал несколько решений, которые были опубликованы здесь, но ни одно из них не работает или не применяется.

Проблема: я пытаюсь расшифровать HTTP-запрос, отправленный с какого-либо оборудования.Однако я не получаю HTTP-запрос, преобразованный в правильное количество байтов, которое соответствует моим методам расшифровки (я думаю, что это проблема?).

Вот мой код:

System.Text.Encoding enc = System.Text.Encoding.ASCII;
System.Text.Encoding req = System.Text.Encoding.ASCII;

if (curContext != null)
{
    string decrypted = "";
    int totalBytes = curContext.Request.TotalBytes;
    StreamReader sr = new StreamReader(curContext.Request.InputStream);
    string request = sr.ReadToEnd();

    if (!String.IsNullOrEmpty(request)) 
    {
        using (RijndaelManaged myRijndael = new RijndaelManaged())
        {
            myRijndael.Mode = CipherMode.ECB;
            myRijndael.Padding = PaddingMode.None;
            byte[] key = enc.GetBytes(WebConfigurationManager.AppSettings["32B"].ToString());
            myRijndael.KeySize = 256;
            myRijndael.Key = key;

            decrypted = DecryptStringFromBytes(req.GetBytes(request), myRijndael.Key);
        }
    }
}

И метод расшифровки:

static string DecryptStringFromBytes(byte[] cipherText, byte[] Key)
{
    using (RijndaelManaged rijAlg = new RijndaelManaged())
    {
        rijAlg.Key = Key;
        rijAlg.Mode = CipherMode.ECB;
        rijAlg.Padding = PaddingMode.None;

        // Create a decrytor to perform the stream transform.
        ICryptoTransform decryptor = rijAlg.CreateDecryptor();

        // Create the streams used for decryption.
        using (MemoryStream msDecrypt = new MemoryStream(cipherText))
        {
            using (CryptoStream csDecrypt = new CryptoStream(msDecrypt, decryptor, CryptoStreamMode.Read))
            {
                using (StreamReader srDecrypt = new StreamReader(csDecrypt))
                {
                    // Read the decrypted bytes from the decrypting stream
                    // and place them in a string.
                    plaintext = srDecrypt.ReadToEnd();
                }
            }
        }
    }
}

На srDecrypt.ReadToEnd () я получаю сообщение об ошибке, указанное в заголовке.

Я довольно новичок в этом, поэтому я не уверенгде я иду не так.Любой совет будет принят во внимание.Спасибо ~!

Ответы [ 3 ]

0 голосов
/ 30 марта 2012

Попробуйте вместо этого в нижней части вашего метода расшифровки:

int plainByteCount = int.MinValue;

// Create the streams used for decryption.
using (MemoryStream msDecrypt = new MemoryStream(cipherText))
{
  using (CryptoStream csDecrypt = new CryptoStream(msDecrypt, decryptor, CryptoStreamMode.Read))
  {
    plainBytes = new byte[cipherText.Length];
    plainByteCount = cryptoStream.Read(plainBytes, 0, plainBytes.Length);
  }
}

string plainText = Encoding.UTF8.GetString(plainBytes, 0, plainByteCount);

return plainText;
0 голосов
/ 30 марта 2012

Я думаю, я мог бы найти вашу проблему.Согласно конструктору для StreamReader кодировка по умолчанию - UTF8Encoding.Попытка использовать другую конструкторскую перегрузку и передать кодировку ASCII:

StreamReader sr = new StreamReader(
   curContext.Request.InputStream, Encoding.ASCII);
string request = sr.ReadToEnd();
0 голосов
/ 30 марта 2012

Последовательность преобразования «поток в строку в байты» выглядит очень неправильно.Убедитесь, что вам действительно нужно сделать это вместо простого чтения байтов из ответа.

...