我正在尝试将一段Java代码移植到.NET中,该代码采用Base64编码的字符串,将其转换为字节数组,然后使用其制作X.509证书以获得RSA加密的模数和指数。

这是我要转换的Java代码:

byte[] externalPublicKey = Base64.decode("base 64 encoded string");
KeyFactory keyFactory = KeyFactory.getInstance("RSA");
EncodedKeySpec publicKeySpec = new X509EncodedKeySpec(externalPublicKey);
Key publicKey = keyFactory.generatePublic(publicKeySpec);
RSAPublicKey pbrtk = (java.security.interfaces.RSAPublicKey) publicKey;
BigInteger modulus = pbrtk.getModulus();
BigInteger pubExp = pbrtk.getPublicExponent();

我一直在尝试找出将其转换为.NET的最佳方法。到目前为止,我已经提出了:
byte[] bytes = Convert.FromBase64String("base 64 encoded string");
X509Certificate2 x509 = new X509Certificate2(bytes);
RSA rsa = (RSA)x509.PrivateKey;
RSAParameters rsaParams = rsa.ExportParameters(false);
byte[] modulus = rsaParams.Modulus;
byte[] exponent = rsaParams.Exponent;

在我看来,它应该可以工作,但是当我使用Java代码中以base 64编码的字符串生成X509证书时,它将抛出CryptographicException。我收到的确切消息是:



Java的X.509实现只是与.NET不兼容,还是我从Java转换为.NET时做错了什么?

还是在这种情况下根本就没有从Java到.NET的转换?

最佳答案

看来您的base64编码数据不代表X.509证书:



用Java导出整个X.509证书,或尝试在.NET框架中找到等效的X509EncodedKeySpec类。

关于c# - 将字节数组转换为X.509证书,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/2534127/

10-11 05:59