c java rsa签名_c# 使用 java的 rsa 进行签名

1 ///

2 ///类名:RSAFromPkcs83 ///功能:RSA加密、解密、签名、验签4 ///详细:该类对Java生成的密钥进行解密和签名以及验签专用类,不需要修改5 ///版本:3.06 ///日期:2013-07-087 ///说明:8 ///以下代码只是为了方便商户测试而提供的样例代码,商户可以根据自己网站的需要,按照技术文档编写,并非一定要使用该代码。9 ///

10 public sealed classRSAFromPkcs811 {12 ///

13 ///签名14 ///

15 /// 待签名字符串

16 /// 私钥

17 /// 编码格式

18 /// 签名后字符串

19 public static string sign(string content, string privateKey, stringinput_charset)20 {21 byte[] Data =Encoding.GetEncoding(input_charset).GetBytes(content);22 RSACryptoServiceProvider rsa =DecodePemPrivateKey(privateKey);23 SHA256 sh = newSHA256CryptoServiceProvider();24 //SHA1 sh = new SHA1CryptoServiceProvider();

25 byte[] signData =rsa.SignData(Data, sh);26 returnConvert.ToBase64String(signData);27 }28

29 ///

30 ///验签31 ///

32 /// 待验签字符串

33 /// 签名

34 /// 公钥

35 /// 编码格式

36 /// true(通过),false(不通过)

37 public static bool verify(string content, string signedString, string publicKey, stringinput_charset)38 {39 bool result = false;40 byte[] Data =Encoding.GetEncoding(input_charset).GetBytes(content);41 byte[] data =Convert.FromBase64String(signedString);42 RSAParameters paraPub =ConvertFromPublicKey(publicKey);43 RSACryptoServiceProvider rsaPub = newRSACryptoServiceProvider();44 rsaPub.ImportParameters(paraPub);45 //SHA1 sh = new SHA1CryptoServiceProvider();

46 SHA256 sh = newSHA256CryptoServiceProvider();47 result =rsaPub.VerifyData(Data, sh, data);48 returnresult;49 }50

51 ///

52 ///加密53 ///

54 /// 需要加密的字符串

55 /// 公钥

56 /// 编码格式

57 /// 明文

58 public static string encryptData(string resData, string publicKey, stringinput_charset)59 {60 byte[] DataToEncrypt =Encoding.ASCII.GetBytes(resData);61 string result =encrypt(DataToEncrypt, publicKey, input_charset);62 returnresult;63 }64

65

66 ///

67 ///解密68 ///

69 /// 加密字符串

70 /// 私钥

71 /// 编码格式

72 /// 明文

73 public static string decryptData(string resData, string privateKey, stringinput_charset)74 {75 byte[] DataToDecrypt =Convert.FromBase64String(resData);76 string result = "";77 for (int j = 0; j < DataToDecrypt.Length / 128; j++)78 {79 byte[] buf = new byte[128];80 for (int i = 0; i < 128; i++)81 {82

83 buf[i] = DataToDecrypt[i + 128 *j];84 }85 result +=decrypt(buf, privateKey, input_charset);86 }87 returnresult;88 }89

90 #region 内部方法

91

92 private static string encrypt(byte[] data, string publicKey, stringinput_charset)93 {94 RSACryptoServiceProvider rsa =DecodePemPublicKey(publicKey);95 SHA1 sh = newSHA1CryptoServiceProvider();96 byte[] result = rsa.Encrypt(data, false);97

98 returnConvert.ToBase64String(result);99 }100

101 private static string decrypt(byte[] data, string privateKey, stringinput_charset)102 {103 string result = "";104 RSACryptoServiceProvider rsa =DecodePemPrivateKey(privateKey);105 SHA1 sh = newSHA1CryptoServiceProvider();106 byte[] source = rsa.Decrypt(data, false)

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值