.NET等效于Java KeyFactory.getInstance“ RSA” /“ RSA / ECB / PKCS1Padding”

use*_*567 2 .net c# java

我有以下代码,

public static String encrypt(String plainText, String key){
    try{
        PublicKey publicKey = KeyFactory.getInstance("RSA").generatePublic(new X509EncodedKeySpec(Base64.decode(key, Base64.DEFAULT)));
        Cipher cipher = Cipher.getInstance("RSA/ECB/PKCS1Padding");
        cipher.init(Cipher.ENCRYPT_MODE, publicKey);
        return Base64.encodeToString(cipher.doFinal(plainText.getBytes("UTF-8")),Base64.DEFAULT);
    }catch (Exception e) {
        e.printStackTrace();
    }
    return null;
}
Run Code Online (Sandbox Code Playgroud)

我想将其转换为C#。我已经尝试过CryptUtils,但是它不起作用https://github.com/ServiceStack/ServiceStack/blob/master/src/ServiceStack.Common/CryptUtils.cs

样本键

MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ9AMIIBCgKCAQEAoqB1N9kugk4UKYnbh0fcg3qYyYKP0m4B
MjWd05ReeAdj+7JRYDEKO6xthDdVSdRO1/2V+YtY8DnXWnxRaICwu8235s3imZCyqgYnomPWdY+F
K540oTz/zug+9wbrlzt/WQFUU4lPlQbzm/Gjw8XfaCozT0e3bnWQcD7rORCOyuJgwSGgREjTv1ss
pgEaKTMknii9vpGZLeAXwoeIYROhuT4IoIkPDhtY0/UZiCi6v7Ja2dmy53VlWIkcm3rcnSJdvpXr
OgiHvaNABHmeymNycNqd6WUaysBRheluQ86nq/2nZPW0gcvmYt5zbMMYX3yY/n2WtAKeNQBAEW1q
b0s6MwIDAQAB
Run Code Online (Sandbox Code Playgroud)

可能的加密值,

Y3VTjghDnTrCeG8C/RklKsJ3Y0Mt89sSGGin28E4iQPQvKqeZBws7rBQEZaRamDWftxCkEYZs4Qh
V2l4IVlrawdtRmQlcQh8McrpqP/97Gz8pEDEYnqA7kqBTqZw0Z5o0WsshGSwiAQ9wNSym4xHejkq
zrKxWP8XCMkcT0NlKlRMoqKKICFKZbqWeSQkQM5y9OEcmB6inNNkJCoM1Ip48+cK3cOE6dqXNVrl
sSTZ8WQKwoB3dJmcYqexR3kAvBYdX6ZxEF+2+6b9h8+tc5G7Y5R2eqycyUossdkCcI3fNVhyc72P
axCjZFWZUgfDGCxg1WNhStrH9L8c59P35JKKug==
Run Code Online (Sandbox Code Playgroud)

zai*_*man 5

由于我没有私钥,因此无法解密,但是至少这会产生正确的加长值。

因此,请尝试以下操作(您需要bouncycastle才能阅读pem):

using Org.BouncyCastle.Crypto;
using Org.BouncyCastle.Crypto.Parameters;
using Org.BouncyCastle.Security;

 var keyBytes =
    Convert.FromBase64String(
      "MIIBI...."); // your key here

  AsymmetricKeyParameter asymmetricKeyParameter = PublicKeyFactory.CreateKey(keyBytes);
  RsaKeyParameters rsaKeyParameters = (RsaKeyParameters)asymmetricKeyParameter;
  RSAParameters rsaParameters = new RSAParameters();
  rsaParameters.Modulus = rsaKeyParameters.Modulus.ToByteArrayUnsigned();
  rsaParameters.Exponent = rsaKeyParameters.Exponent.ToByteArrayUnsigned();
  RSACryptoServiceProvider rsa = new RSACryptoServiceProvider();
  rsa.ImportParameters(rsaParameters);

  byte[] plaintext = Encoding.UTF8.GetBytes("amount=1&currency=AED");
  byte[] ciphertext = rsa.Encrypt(plaintext, false);
  string cipherresult = Convert.ToBase64String(ciphertext);
Run Code Online (Sandbox Code Playgroud)