Exemple #1
0
        /// <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);
        }
Exemple #2
0
        /// <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);
        }