0

我一直在研究尝试使用 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() 上,我收到标题中所述的错误消息。

我对此很陌生,所以我不确定我哪里出错了。任何意见,将不胜感激。谢谢~!

4

3 回答 3

0

“流到字符串到字节”的转换顺序感觉很不对劲。确保您确实需要这样做,而不是简单地从响应中读取字节。

于 2012-03-30T15:57:48.880 回答
0

请在 Decrypt 方法的底部尝试此操作:

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;
于 2012-03-30T16:00:54.917 回答
0

我想我可能发现了你的问题。根据 for 的构造函数StreamReader,默认编码是UTF8Encoding. 尝试使用其他构造函数重载并传入 ASCII 编码:

StreamReader sr = new StreamReader(
   curContext.Request.InputStream, Encoding.ASCII);
string request = sr.ReadToEnd();
于 2012-03-30T19:50:51.497 回答