0

我正在尝试使用库 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;
}
4

1 回答 1

2

问题是您的 FromHex 函数。

将其与如何将十六进制字符串转换为字节数组的最佳答案进行了交换?并得到了正确的结果。

不过,不确定您的 FromHex 出了什么问题(在功能方面)——您可能应该弄清楚这一点。

于 2016-04-07T14:16:52.510 回答