4

您好,我有一个在 .net 中生成的 RSA 私钥和公钥

以这种格式

string privateKey = "<RSAKeyValue>" +
                         "<Modulus>...kCFhsjB4xMW49mrx5B/Ga...</Modulus>" +
                         "<Exponent>...</Exponent>" +
                         "<P>...7bRCrQVgVIfXdTIH3iY8x...</P>" +
                         "<Q>...4SiQDhrAZADuFDTr7bRCrQVgVIfXdTIH3iY8x...</Q>" +
                         "<DP>...ZADuFDTr7bRCrQVgVIfXdT...</DP>" +
                         "<DQ>...4SiQDhrAZADuFDTr...</DQ>" +
                         "<InverseQ>...sjB4xMW49mrx5B/Ga...</InverseQ>" +
                         "<D>...SiQDhrAZADuFDTr7bRCrQVgVIf...</D>" +
                     "</RSAKeyValue>";

我怎样才能转换它,以便我可以在 php openssl 函数中使用它来加密和解密数据?我需要转换公钥和私钥。

也许在linux中使用openssl bash命令我可以指定我自己的模数、指数等?

有任何想法吗?

谢谢

4

1 回答 1

1

不幸的是,我还没有找到您所描述的确切问题的解决方案,但是,您可能会发现一些有用的解决方法:

  • 如果您有权访问 .NET 源,则可以将密钥导出为 PEM。(我不肯定这是否可以通过标准系统库实现,但BouncyCastle肯定支持它。
  • 如果你能负担得起使用另一种语言来翻译密钥,这在 perl 中可以相对容易地完成。

    使用 Crypt::OpenSSL::RSA;
    使用 Crypt::OpenSSL::Bignum;
    使用 MIME::Base64;
    $modulus = Crypt::OpenSSL::Bignum->new_from_bin(decode_base64($XMLModulus));
    $exponent= Crypt::OpenSSL::Bignum->new_from_bin(decode_base64($XMLExponent));
    # 你可以读入的其余参数与前两个相同
    # dq、dp 和 inverseQ 都不需要
    $privateKey = Crypt::OpenSSL::RSA->($modulus, $exponent, $d, $p, $q)
    # 以 PHP 应该支持的标准二进制形式 (DER) 输出它。print $privateKey->get_private_key_string()
    # 如果需要PEM,openssl绝对可以转换。

抱歉,我无法为您提供适当的 PHP 解决方案。但希望 C# 解决方案能够工作。

于 2010-05-04T16:36:45.107 回答