3

我正在尝试在 C# 和 PHP 之间构建一个简单的 RSA 加密解密过程。我已经使用 phpseclib( http://phpseclib.sourceforge.net/ ) 完成了 PHP 中的加密和 C# 中的 decrpyt。但是,我在第 2103 行收到“C:\xampp\htdocs\Crypt\RSA.php 中的解密错误”这部分:

if ($lHash != $lHash2) {
        user_error('Decryption error', E_USER_NOTICE);
        return false;
    }

C# 中的加密我使用了这组代码:

RSACryptoServiceProvider rsaCryptoServiceProvider = new RSACryptoServiceProvider(dwKeySize);
        rsaCryptoServiceProvider.FromXmlString(publickey);
        int keySize = dwKeySize / 8;
        byte[] bytes = Encoding.UTF32.GetBytes(inputString);
        // The hash function in use by the .NET RSACryptoServiceProvider here is SHA1
        // int maxLength = ( keySize ) - 2 - ( 2 * SHA1.Create().ComputeHash( rawBytes ).Length );
        int maxLength = keySize - 42;
        int dataLength = bytes.Length;
        int iterations = dataLength / maxLength;
        StringBuilder stringBuilder = new StringBuilder();
        for (int i = 0; i <= iterations; i++)
        {
            byte[] tempBytes = new byte[(dataLength - maxLength * i > maxLength) ? maxLength : dataLength - maxLength * i];
            Buffer.BlockCopy(bytes, maxLength * i, tempBytes, 0, tempBytes.Length);
            byte[] encryptedBytes = rsaCryptoServiceProvider.Encrypt(tempBytes, true);
            // Be aware the RSACryptoServiceProvider reverses the order of encrypted bytes after encryption and before decryption.
            // If you do not require compatibility with Microsoft Cryptographic API (CAPI) and/or other vendors.
            // Comment out the next line and the corresponding one in the DecryptString function.
            Array.Reverse(encryptedBytes);
            // Why convert to base 64?
            // Because it is the largest power-of-two base printable using only ASCII characters
            stringBuilder.Append(Convert.ToBase64String(encryptedBytes));
        }
        string ciphertext = stringBuilder.ToString();

和我的基本 PHP 代码来 decrpyt:

$rsa->loadKeyfromXML($privatekey);  
$ciphertext = file_get_contents('cipher.txt');
$ciphertext = base64_decode(strrev($ciphertext));

//$rsa->setEncryptionMode(CRYPT_RSA_ENCRYPTION_PKCS1);

$plaintext = $rsa->decrypt($ciphertext);

我试过 PKC1 它还在 Crypt/RSA.php 中给出了另一个错误

4

4 回答 4

2

是的,我自己找到了解决方案。我更改了加密行:

byte[] bytes = Encoding.UTF32.GetBytes(inputString);  ==> byte[] bytes = Encoding.Default.GetBytes(inputString);

正如@Ryan 所说:

$ciphertext = base64_decode(strrev($ciphertext));  ==> $ciphertext = strrev(base64_decode($ciphertext));

感谢您的尝试。

于 2013-04-04T10:57:02.940 回答
0

由于您Array.Reverse在 C# 中进行操作,因此我冒昧地猜测strrevPHP 是不必要的。

此外,phpseclib 的 Crypt_RSA 没有loadKeyfromXML. 你从哪里得到的?做$rsa->loadKey()应该就够了。

最后,我的猜测是 PKCS1 是必需的。您使用它时遇到的错误是什么?

于 2013-04-03T18:16:06.443 回答
0

在我看来,在 PHP 中,您正在使用 Base64 编码的密文,将其反转,然后尝试对其进行 Base64 解码?我认为您想先对其进行解码,然后再反转结果。他们不是一回事。

首先是否有必要进行这种逆转,我不能说。

于 2013-04-03T20:03:57.327 回答
0

我不得不说我没有完全解决你的问题,但它似乎是如何在 C# 和 PHP 中结合 RSA 加密。这样做我也遇到了一些麻烦,对于仍然感兴趣的每个人,我编写了一个工作项目来执行此操作,C# 程序和 PHP 脚本都创建 RSA 密钥并交换它们,然后加密通信(参见此处)。

于 2015-04-27T12:51:41.113 回答