/// <summary> /// 解析远程模拟提交后返回的信息 /// </summary> /// <param name="pStrText">要解析的字符串</param> /// <param name="pSignType">加密方式</param> /// <param name="pPrivateKey">RSA加密算法的私有密钥</param> /// <param name="InputCharset">编码方式</param> /// <returns>解析结果</returns> public static Dictionary <string, string> ParseResponse(string pStrText, string pSignType, string pPrivateKey, string InputCharset) { //以“&”字符切割字符串 string[] strSplitText = pStrText.Split('&'); //把切割后的字符串数组变成变量与数值组合的字典数组 Dictionary <string, string> dicText = new Dictionary <string, string>(); for (int i = 0; i < strSplitText.Length; i++) { //获得第一个=字符的位置 int nPos = strSplitText[i].IndexOf('='); //获得字符串长度 int nLen = strSplitText[i].Length; //获得变量名 string strKey = strSplitText[i].Substring(0, nPos); //获得数值 string strValue = strSplitText[i].Substring(nPos + 1, nLen - nPos - 1); //放入字典类数组中 dicText.Add(strKey, strValue); } if (dicText["res_data"] != null) { //解析加密部分字符串(RSA与MD5区别仅此一句) if (pSignType == "0001") { dicText["res_data"] = RSAFromPkcs8.DecryptData(dicText["res_data"], pPrivateKey, InputCharset); } //token从res_data中解析出来(也就是说res_data中已经包含token的内容) XmlDocument xmlDoc = new XmlDocument(); try { xmlDoc.LoadXml(dicText["res_data"]); string strRequest_token = xmlDoc.SelectSingleNode("/direct_trade_create_res/request_token").InnerText; dicText.Add("request_token", strRequest_token); } catch (Exception exp) { throw exp; } } return(dicText); }
/// <summary> /// 解密 /// </summary> /// <param name="pContent">待解密字符串</param> /// <param name="pPrivateKey">商户私钥</param> /// <param name="pInputCharset">编码格式</param> /// <returns>返回明文</returns> public static string Decrypt(string pContent, string pPrivateKey, string pInputCharset) { string strDecryptData = RSAFromPkcs8.DecryptData(pContent, pPrivateKey, pInputCharset); return(strDecryptData); }