/// <summary> /// 请求 /// </summary> /// <returns></returns> private WeixinDataHelper Post(string xml, string url, int timeOut, bool isUseCert = false) { var start = DateTime.Now; //请求开始时间 string response = HttpService.Post(xml, url, isUseCert, timeOut, this.CertPath, this.CertPassword); //调用HTTP通信接口以提交数据到API var end = DateTime.Now; double timeCost = (end - start).TotalMilliseconds;//获得接口耗时 //将xml格式的结果转换为对象以返回 WeixinDataHelper result = new WeixinDataHelper(this.WeixinKey); if (response.StartsWith("<xml>")) { //若接口调用失败会返回xml格式的结果 result.FromXml(response); } else { //接口调用成功则返回非xml格式的数据 result.SetValue("result", response); } ReportCostTime(url, (int)timeCost, result);//测速上报 //RequestUrl,ElapsedTime,HttpMethod,RequestContent result.SetValue("requestUrl", url); result.SetValue("elapsedTime", timeCost); result.SetValue("httpMethod", "Post"); result.SetValue("requestContent", xml); return(result); }
private string ToXml(WeixinDataHelper inputObj) { if (!string.IsNullOrEmpty(SubMchId)) { inputObj.SetValue("sub_mch_id", this.SubMchId); } inputObj.SetValue("appid", this.AppId); //公众账号ID inputObj.SetValue("mch_id", this.MCHID); //商户号 inputObj.SetValue("nonce_str", Guid.NewGuid().ToString().Replace("-", "")); //随机字符串 inputObj.SetValue("sign", inputObj.MakeSign()); //签名 return(inputObj.ToXml()); }
/** * * 测速上报接口实现 * @param WeixinDataHelper inputObj 提交给测速上报接口的参数 * @param int timeOut 测速上报接口超时时间 * @throws WeixinPayException * @return 成功时返回测速上报接口返回的结果,其他抛异常 */ private WeixinDataHelper Report(WeixinDataHelper inputObj, int timeOut = 1) { string url = "https://api.mch.weixin.qq.com/payitil/report"; //检测必填参数 if (!inputObj.IsSet("interface_url")) { throw new WeixinPayException("接口URL,缺少必填参数interface_url!"); } if (!inputObj.IsSet("return_code")) { throw new WeixinPayException("返回状态码,缺少必填参数return_code!"); } if (!inputObj.IsSet("result_code")) { throw new WeixinPayException("业务结果,缺少必填参数result_code!"); } if (!inputObj.IsSet("user_ip")) { throw new WeixinPayException("访问接口IP,缺少必填参数user_ip!"); } if (!inputObj.IsSet("execute_time_")) { throw new WeixinPayException("接口耗时,缺少必填参数execute_time_!"); } inputObj.SetValue("time", DateTime.Now.ToString("yyyyMMddHHmmss"));//商户上报时间 string xml = ToXml(inputObj); string response = HttpService.Post(xml, url, false, timeOut, this.CertPath, this.CertPassword); WeixinDataHelper result = new WeixinDataHelper(this.WeixinKey); result.FromXml(response); return(result); }
/** * 下载对账单 * @param WeixinDataHelper inputObj 提交给下载对账单API的参数 * @param int timeOut 接口超时时间 * @throws WeixinPayException * @return 成功时返回,其他抛异常 */ public WeixinDataHelper DownloadBill(WeixinDataHelper inputObj, int timeOut = 6) { string url = "https://api.mch.weixin.qq.com/pay/downloadbill"; //检测必填参数 if (!inputObj.IsSet("bill_date")) { throw new WeixinPayException("对账单接口中,缺少必填参数bill_date!"); } string xml = ToXml(inputObj); //Log.Debug("WeixinPayApi", "DownloadBill request : " + xml); string response = HttpService.Post(xml, url, false, timeOut, this.CertPath, this.CertPassword);//调用HTTP通信接口以提交数据到API //Log.Debug("WeixinPayApi", "DownloadBill result : " + response); WeixinDataHelper result = new WeixinDataHelper(inputObj.WeixinKey); //若接口调用失败会返回xml格式的结果 if (response.Substring(0, 5) == "<xml>") { result.FromXml(response); } //接口调用成功则返回非xml格式的数据 else { result.SetValue("result", response); } return(result); }
/** * * 测速上报 * @param string interface_url 接口URL * @param int timeCost 接口耗时 * @param WeixinDataHelper inputObj参数数组 */ private void ReportCostTime(string interface_url, int timeCost, WeixinDataHelper inputObj) { //如果不需要进行上报 if (this.REPORT_LEVENL == 0) { return; } //如果仅失败上报 if (this.REPORT_LEVENL == 1 && inputObj.IsSet("return_code") && inputObj.GetValue("return_code").ToString() == "SUCCESS" && inputObj.IsSet("result_code") && inputObj.GetValue("result_code").ToString() == "SUCCESS") { return; } //上报逻辑 WeixinDataHelper data = new WeixinDataHelper(this.WeixinKey); data.SetValue("interface_url", interface_url); data.SetValue("execute_time_", timeCost); //返回状态码 if (inputObj.IsSet("return_code")) { data.SetValue("return_code", inputObj.GetValue("return_code")); } //返回信息 if (inputObj.IsSet("return_msg")) { data.SetValue("return_msg", inputObj.GetValue("return_msg")); } //业务结果 if (inputObj.IsSet("result_code")) { data.SetValue("result_code", inputObj.GetValue("result_code")); } //错误代码 if (inputObj.IsSet("err_code")) { data.SetValue("err_code", inputObj.GetValue("err_code")); } //错误代码描述 if (inputObj.IsSet("err_code_des")) { data.SetValue("err_code_des", inputObj.GetValue("err_code_des")); } //商户订单号 if (inputObj.IsSet("out_trade_no")) { data.SetValue("out_trade_no", inputObj.GetValue("out_trade_no")); } //设备号 if (inputObj.IsSet("device_info")) { data.SetValue("device_info", inputObj.GetValue("device_info")); } if (!string.IsNullOrEmpty(this.UserIP)) { data.SetValue("user_ip", this.UserIP);//终端ip } try { Report(data); } catch (WeixinPayException ex) { //不做任何处理 } }