首页 > 解决方案 > RSA 签名 Java 到 C#

问题描述

我有一个创建签名的工具。我正在寻找 dot net core 2.1 中的等效代码。

Java 代码:sign(currentdate,'some text','SHA1WithRSA')

public String sign(String date, String subjectId, String algorithm){
    Signature rsa = Signature.getInstance(algorithm);
    rsa.initSign(this.getPrivate());
    rsa.update(subjectId.getBytes());
    rsa.update(date.getBytes());
    String signature = new String(Base64.getEncoder().encode(rsa.sign()));
    return signature;
}

public PrivateKey getPrivate() {
    String privateKeyPEM = "<This is the private key string";

    byte[] encoded = Base64.getDecoder().decode(privateKeyPEM);
    KeyFactory kf = KeyFactory.getInstance("RSA");
    PKCS8EncodedKeySpec spec = new PKCS8EncodedKeySpec(encoded);
    return kf.generatePrivate(spec);
}

建议使用或不使用 3rd 方工具为上述生成 dot net core 2.1 等效代码的方法。

标签: javac#.net-corecryptographyrsa

解决方案


这是我使用Portable.BouncyCastle图书馆的工作。

 private string GetSign(string data)
        {
            using (var rsa = new RSACryptoServiceProvider())
            {
                var privateKey = new StringBuilder();
                privateKey.AppendLine("-----BEGIN RSA PRIVATE KEY-----");
                privateKey.AppendLine("private key as string");
                privateKey.AppendLine("-----END RSA PRIVATE KEY-----");

                var pem = new PemReader(new StringReader(privateKey.ToString()));
                var keyPair = (AsymmetricCipherKeyPair)pem.ReadObject();
                var privateKeyParameters = (RsaPrivateCrtKeyParameters)keyPair.Private;
                var rsaParameters = DotNetUtilities.ToRSAParameters(privateKeyParameters);

                rsa.ImportParameters(rsaParameters);
                var sign = rsa.SignData(Encoding.UTF8.GetBytes(data), new HashAlgorithmName("SHA1") /*pass your algorithm*/,
                    RSASignaturePadding.Pkcs1);

                return Convert.ToBase64String(sign);
            }
        }

推荐阅读