在C#中使用Bouncy Castle RC4算法解密字符串

时间:2016-04-07 13:40:59

标签: c# encryption bouncycastle rc4-cipher

我正在尝试使用库Bouncy Castle进行解密。但解密的字符串不正确。我得到的值是Aa1ŽYY445Ló,但正确的值应该是Aa11YY445LL。我做错了什么?当我尝试解密http://rc4.online-domain-tools.com/上的字符串时,我得到了正确的结果。

代码示例:

string textToDecrypt = HexDumper.FromHex("E5497380DC724B28284D80");
var key = Encoding.UTF8.GetBytes("heslo");
var cipher = new RC4Engine();
cipher.Init(true, new KeyParameter(key));

byte[] inBytes = UTF8Encoding.GetEncoding(1252).GetBytes(textToDecrypt);
byte[] outBuffer = new byte[1024 * 4];
cipher.ProcessBytes(inBytes, 0, inBytes.Length, outBuffer, 0);

// Output must be 41 61 31 31 59 59 34 34 35 4c 4c -> Aa11YY445LL
var textDecrypted = ASCIIEncoding.GetEncoding(1252).GetString(outBuffer);
int indexOf0 = textDecrypted.IndexOf("\0");
if (indexOf0 > 0)
{
    textDecrypted = textDecrypted.Substring(0, indexOf0);
    MessageBox.Show(textDecrypted);
}

public static string FromHex(string hexString)
{
    string StrValue = "";
    while (hexString.Length > 0)
    {
        StrValue += System.Convert.ToChar(System.Convert.ToUInt32(hexString.Substring(0, 2), 16)).ToString();
        hexString = hexString.Substring(2, hexString.Length - 2);
    }
    return StrValue;
}

1 个答案:

答案 0 :(得分:2)

问题在于你的FromHex功能。

使用How can I convert a hex string to a byte array?的最高回答交换它并得到正确的结果。

不确定具体与你的FromHex有什么不对(在功能方面) - 你应该明白这一点。