RSA使用PHP签名,使用C#验证

时间:2014-03-22 15:56:58

标签: c# php rsa signing phpseclib

不幸的是我还没有发现任何适合我的东西,所以我会创建一个新问题 我的PHP代码(使用phpseclib的RSA)签署字符串,因为您可能会注意到代码是验证许可证代码。

<?php
include('Crypt/RSA.php');

$rsa = new Crypt_RSA();
//$rsa->setPassword('password');
$rsa->loadKey('-----BEGIN RSA PRIVATE KEY-----
...
-----END RSA PRIVATE KEY-----
'); // private key

$plaintext = 'AAAAA-AAAAA-AAAAA-AAAAA';

$rsa->setSignatureMode(CRYPT_RSA_SIGNATURE_PKCS1);
$signature = $rsa->sign($plaintext);
echo base64_encode($signature);

应验证响应的C#代码:

            bool success = false;
            using (var rsa = new RSACryptoServiceProvider())
            {
                StreamReader reader = new StreamReader(dataStream);
                String signedString = reader.ReadToEnd();
                byte[] signedBytes = Convert.FromBase64String(signedString);
                byte[] bytesToVerify = Encoding.UTF8.GetBytes(value);
                try
                {
                    RSAParameters parameters = new RSAParameters();
                    parameters.Exponent = new byte[] { 0x01, 0x10, 0x01 };
                    parameters.Modulus = OtherClass.StringToByteArray(Program.Modulus);
                    rsa.ImportParameters(parameters);

                    success = rsa.VerifyData(bytesToVerify, new SHA1CryptoServiceProvider(), signedBytes);
                }
                catch (CryptographicException e)
                {
                    Console.WriteLine(e.Message);
                }
                finally
                {
                    rsa.PersistKeyInCsp = false;
                }
            }

dataStream是webrequest的响应流。

1 个答案:

答案 0 :(得分:1)

我现在通过另一种加载密钥的方式解决了这个问题 我已使用此在线转换器将我的PEM密钥转换为XML密钥:https://superdry.apphb.com/tools/online-rsa-key-converter

所以我将try {...}部分更改为:

rsa.FromXmlString("{XML_KEY}");
success = rsa.VerifyData(bytesToVerify, new SHA1CryptoServiceProvider(), signedBytes);

现在它运作得很好。我想我真的不懂如何通过模数和指数加载一个密钥。