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)