7

我有一个用 C# 编写的加密工具,它以字符串作为输入。当我在我的 windows 机器上运行编译的 exe 文件时,我得到的输出与我在远程 UNIX 服务器上使用单声道运行它时不同。

这是一个例子:

视窗:

"encrypt.exe 01/01"
Output:
eR4et6LR9P19BfFnhGwPfA==

Unix:

"mono encrypt.exe 01/01"
Output:
Pa8pJCYBN7+U+R705TFq7Q==

我什至尝试将输入值放入脚本中,然后再次编译并运行它,我得到了相同的结果。

解密函数位于远程 Web 服务上,并使用硬编码的密钥和 IV 值(我正在使用这些值进行加密),解密输出:

Input (String generated on windows):
eR4et6LR9P19BfFnhGwPfA==
Output:
01/01

Input (String generated on Unix):
Pa8pJCYBN7+U+R705TFq7Q==
Output:
????1

这是加密函数:

string text = args[0];
byte[] clearData = Encoding.Unicode.GetBytes(text);
PasswordDeriveBytes bytes = new PasswordDeriveBytes(password, new byte[] { 0x19, 0x76, 0x61, 110, 0x20, 0x4d, 0x65, 100, 0x76, 0x65, 100, 0x65, 0xf6 });
string a = Convert.ToBase64String(Encrypt(clearData, bytes.GetBytes(0x20), bytes.GetBytes(0x10)));
Console.Write(a);

public static byte[] Encrypt(byte[] clearData, byte[] Key, byte[] IV)
{
    MemoryStream stream = new MemoryStream();
    Rijndael rijndael = Rijndael.Create();
    rijndael.Key = Key;
    rijndael.IV = IV;
    CryptoStream stream2 = new CryptoStream(stream, rijndael.CreateEncryptor(), CryptoStreamMode.Write);
    stream2.Write(clearData, 0, clearData.Length);
    stream2.Close();
    return stream.ToArray();
}

这是解密函数(我无法对此进行更改):

byte[] cipherData = Convert.FromBase64String(encryptedString);
PasswordDeriveBytes bytes2 = new PasswordDeriveBytes(password, new byte[] { 0x19, 0x76, 0x61, 110, 0x20, 0x4d, 0x65, 100, 0x76, 0x65, 100, 0x65, 0xf6 });
byte[] buffer2 = Decrypt(cipherData, bytes2.GetBytes(0x20), bytes2.GetBytes(0x10));
string output = Encoding.Unicode.GetString(buffer2);
Console.Write(output); 

public static byte[] Decrypt(byte[] cipherData, byte[] Key, byte[] IV)
{
        MemoryStream stream = new MemoryStream();
        Rijndael rijndael = Rijndael.Create();
        rijndael.Key = Key;
        rijndael.IV = IV;
        CryptoStream stream2 = new CryptoStream(stream, rijndael.CreateDecryptor(), CryptoStreamMode.Write);
        stream2.Write(cipherData, 0, cipherData.Length);
        stream2.Close();
        return stream.ToArray();
}
4

3 回答 3

1

此问题中的问题不是您要处理的问题,但是查看结果的差异,似乎填充是一个问题,因此您可能想查看此问题中的一些回答,但此答案可能有助于解决你的问题。

http://social.msdn.microsoft.com/forums/en-US/clr/thread/3df8d5aa-ea99-4553-b071-42a2ea406c7f/

当 KEY、IV 和 ENCRYPTED DATA 不是所有正确的块大小和“方案”时,就会出现这个问题。避免这个问题的唯一方法是使用算法生成的 IV 和 KEY。您可以使用 GenerateIV 来获取生成 IV 的算法。将其存放在安全的地方,以备不时之需。然后只需调用 encrypt 方法并传入数据。然后算法将加密数据并将 Key 属性设置为新生成的密钥。将此与您的加密数据一起存储。这里的所有都是它的。

虽然已经过时,但有各种不同原因的回应,但如果你能解密,那么差异原因可能是有效的,这里给出:http: //lists.ximian.com/pipermail/mono-list/ 2006-11月/033456.html

所以,如果你可以在一个上加密并在另一个上解密(你能做到这一点吗?)那么如果结果不同会有什么区别呢?

于 2011-05-02T23:49:04.583 回答
0

也许问题是输出是 unicode,并且终端显示的是 ascii。我经常看到?代替被误解的 unicode 字符。

检查字节数组的数值和数量。

Ascii 是 unicode 数量的一半,因为每个字符有两个字节。

于 2011-05-03T01:17:29.087 回答
0

您是否检查过测试字符串是否有新行?Windows 测试字符串会有回车 + 换行,而 Unix 字符串只有换行。

于 2013-03-03T07:42:10.817 回答