c# 使用BouncyCastle.Crypto实现MD5withRSA以及SHA256withRSA进行加解密


c# 使用BouncyCastle.Crypto实现MD5withRSA以及SHA256withRSA进行加解密,加密key使用的是Pkcs8,java使用的是Pkcs8,具体代码如下:

   /// <summary>
   /// 私钥签名
   /// </summary>
   /// <param name="signStr"></param>
   /// <returns></returns>
   public  static string RSAPrivateSign(string signStr, string privateKey,string encoding="UTF-8", string signerSymbol="md5")
   {
       RSACryptoServiceProvider ras = new RSACryptoServiceProvider();
       ras.FromXmlString(RSAPrivateKeyJava2DotNet(privateKey));
       byte[] signBytes = ras.SignData(Encoding.GetEncoding(encoding).GetBytes(signStr), signerSymbol);
       return Convert.ToBase64String(signBytes);
   }

    /// <summary>
    /// 公钥解密
    /// </summary>
    /// <param name="signStr"></param>
    /// <param name="publicKey"></param>
    /// <returns></returns>
    public static bool VerifyRSASign(string signStr, string publicKey,string verifySign,string encoding= "UTF-8", string signerSymbol = "md5")
    {
        RSACryptoServiceProvider ras = new RSACryptoServiceProvider();
        ras.FromXmlString(RSAPublicKeyJava2DotNet(publicKey));
        return ras.VerifyData(Encoding.GetEncoding(encoding).GetBytes(signStr), signerSymbol, Convert.FromBase64String(verifySign));
    }

  /// <summary>
  /// 转换私钥
  /// </summary>
  /// <param name="privateKey"></param>
  /// <returns></returns>
  public static string RSAPrivateKeyJava2DotNet(string privateKey)
  {
      RsaPrivateCrtKeyParameters privateKeyParam = (RsaPrivateCrtKeyParameters)PrivateKeyFactory.CreateKey(Convert.FromBase64String(privateKey));
      return string.Format(
          "<RSAKeyValue><Modulus>{0}</Modulus><Exponent>{1}</Exponent><P>{2}</P><Q>{3}</Q><DP>{4}</DP><DQ>{5}</DQ><InverseQ>{6}</InverseQ><D>{7}</D></RSAKeyValue>",
          Convert.ToBase64String(privateKeyParam.Modulus.ToByteArrayUnsigned()),
          Convert.ToBase64String(privateKeyParam.PublicExponent.ToByteArrayUnsigned()),
          Convert.ToBase64String(privateKeyParam.P.ToByteArrayUnsigned()),
          Convert.ToBase64String(privateKeyParam.Q.ToByteArrayUnsigned()),
          Convert.ToBase64String(privateKeyParam.DP.ToByteArrayUnsigned()),
          Convert.ToBase64String(privateKeyParam.DQ.ToByteArrayUnsigned()),
          Convert.ToBase64String(privateKeyParam.QInv.ToByteArrayUnsigned()),
          Convert.ToBase64String(privateKeyParam.Exponent.ToByteArrayUnsigned())
      );
  }

调用方式:

            var md5withRSA= RSAPayHelper.RSAPrivateSign(str, javaPrivateKey, "GBK", "MD5");
            var sha256WithRSA= RSAPayHelper.RSAPrivateSign(str, javaPrivateKey, "GBK", "SHA256");

希望对大家有所帮助!!!!

  • 6
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值