private static void ReportCostTime(string interface_url, int timeCost, WxPayData inputObj) { if (!inputObj.IsSet("return_code") || !(inputObj.GetValue("return_code").ToString() == "SUCCESS") || !inputObj.IsSet("result_code") || !(inputObj.GetValue("result_code").ToString() == "SUCCESS")) { WxPayData wxPayData = new WxPayData(); wxPayData.SetValue("interface_url", interface_url); wxPayData.SetValue("execute_time_", timeCost); if (inputObj.IsSet("return_code")) { wxPayData.SetValue("return_code", inputObj.GetValue("return_code")); } if (inputObj.IsSet("return_msg")) { wxPayData.SetValue("return_msg", inputObj.GetValue("return_msg")); } if (inputObj.IsSet("result_code")) { wxPayData.SetValue("result_code", inputObj.GetValue("result_code")); } if (inputObj.IsSet("err_code")) { wxPayData.SetValue("err_code", inputObj.GetValue("err_code")); } if (inputObj.IsSet("err_code_des")) { wxPayData.SetValue("err_code_des", inputObj.GetValue("err_code_des")); } if (inputObj.IsSet("out_trade_no")) { wxPayData.SetValue("out_trade_no", inputObj.GetValue("out_trade_no")); } if (inputObj.IsSet("device_info")) { wxPayData.SetValue("device_info", inputObj.GetValue("device_info")); } try { WxPayApi.Report(wxPayData); } catch (WxPayException) { } } }
public static WxPayData Refund(WxPayData inputObj) { string text = "https://api.mch.weixin.qq.com/secapi/pay/refund"; if (!inputObj.IsSet("out_trade_no") && !inputObj.IsSet("transaction_id")) { throw new WxPayException("退款申请接口中,out_trade_no、transaction_id至少填一个!"); } if (!inputObj.IsSet("out_refund_no")) { throw new WxPayException("退款申请接口中,缺少必填参数out_refund_no!"); } if (!inputObj.IsSet("total_fee")) { throw new WxPayException("退款申请接口中,缺少必填参数total_fee!"); } if (!inputObj.IsSet("refund_fee")) { throw new WxPayException("退款申请接口中,缺少必填参数refund_fee!"); } if (!inputObj.IsSet("op_user_id")) { throw new WxPayException("退款申请接口中,缺少必填参数op_user_id!"); } inputObj.SetValue("appid", WxPayConfig.APPID); inputObj.SetValue("mch_id", WxPayConfig.MCHID); inputObj.SetValue("nonce_str", System.Guid.NewGuid().ToString().Replace("-", "")); inputObj.SetValue("sign", inputObj.MakeSign()); string text2 = inputObj.ToXml(); System.DateTime now = System.DateTime.Now; Log.Debug("WxPayApi", "Refund request : " + text2); string text3 = HttpService.Post(text2, text, true, 6); Log.Debug("WxPayApi", "Refund response : " + text3); System.DateTime now2 = System.DateTime.Now; int timeCost = (int)(now2 - now).TotalMilliseconds; WxPayData wxPayData = new WxPayData(); wxPayData.FromXml(text3); WxPayApi.ReportCostTime(text, timeCost, wxPayData); return(wxPayData); }
public static WxPayData Report(WxPayData inputObj) { string url = "https://api.mch.weixin.qq.com/payitil/report"; if (!inputObj.IsSet("interface_url")) { throw new WxPayException("接口URL,缺少必填参数interface_url!"); } if (!inputObj.IsSet("return_code")) { throw new WxPayException("返回状态码,缺少必填参数return_code!"); } if (!inputObj.IsSet("result_code")) { throw new WxPayException("业务结果,缺少必填参数result_code!"); } if (!inputObj.IsSet("user_ip")) { throw new WxPayException("访问接口IP,缺少必填参数user_ip!"); } if (!inputObj.IsSet("execute_time_")) { throw new WxPayException("接口耗时,缺少必填参数execute_time_!"); } inputObj.SetValue("appid", WxPayConfig.APPID); inputObj.SetValue("mch_id", WxPayConfig.MCHID); inputObj.SetValue("user_ip", ""); inputObj.SetValue("time", System.DateTime.Now.ToString("yyyyMMddHHmmss")); inputObj.SetValue("nonce_str", WxPayApi.GenerateNonceStr()); inputObj.SetValue("sign", inputObj.MakeSign()); string text = inputObj.ToXml(); Log.Info("WxPayApi", "Report request : " + text); string text2 = HttpService.Post(text, url, false, 1); Log.Info("WxPayApi", "Report response : " + text2); WxPayData wxPayData = new WxPayData(); wxPayData.FromXml(text2); return(wxPayData); }
public static WxPayData Micropay(WxPayData inputObj) { string text = "https://api.mch.weixin.qq.com/pay/micropay"; if (!inputObj.IsSet("body")) { throw new WxPayException("提交被扫支付API接口中,缺少必填参数body!"); } if (!inputObj.IsSet("out_trade_no")) { throw new WxPayException("提交被扫支付API接口中,缺少必填参数out_trade_no!"); } if (!inputObj.IsSet("total_fee")) { throw new WxPayException("提交被扫支付API接口中,缺少必填参数total_fee!"); } if (!inputObj.IsSet("auth_code")) { throw new WxPayException("提交被扫支付API接口中,缺少必填参数auth_code!"); } inputObj.SetValue("spbill_create_ip", ""); inputObj.SetValue("appid", WxPayConfig.APPID); inputObj.SetValue("mch_id", WxPayConfig.MCHID); inputObj.SetValue("nonce_str", System.Guid.NewGuid().ToString().Replace("-", "")); inputObj.SetValue("sign", inputObj.MakeSign()); string text2 = inputObj.ToXml(); System.DateTime now = System.DateTime.Now; Log.Debug("WxPayApi", "MicroPay request : " + text2); string text3 = HttpService.Post(text2, text, false, 10); Log.Debug("WxPayApi", "MicroPay response : " + text3); System.DateTime now2 = System.DateTime.Now; int timeCost = (int)(now2 - now).TotalMilliseconds; WxPayData wxPayData = new WxPayData(); wxPayData.FromXml(text3); WxPayApi.ReportCostTime(text, timeCost, wxPayData); return(wxPayData); }
/** * * 查询订单 * @param WxPayData inputObj 提交给查询订单API的参数 * @param int timeOut 超时时间 * @throws WxPayException * @return 成功时返回订单查询结果,其他抛异常 */ public static WxPayData OrderQuery(WxPayData inputObj) { string url = "https://api.mch.weixin.qq.com/pay/orderquery"; //检测必填参数 if (!inputObj.IsSet("out_trade_no") && !inputObj.IsSet("transaction_id")) { throw new WxPayException("订单查询接口中,out_trade_no、transaction_id至少填一个!"); } inputObj.SetValue("appid", WxPayConfig.APPID); //公众账号ID inputObj.SetValue("mch_id", WxPayConfig.MCHID); //商户号 inputObj.SetValue("nonce_str", WxPayApi.GenerateNonceStr()); //随机字符串 inputObj.SetValue("sign", inputObj.MakeSign()); //签名 string xml = inputObj.ToXml(); var start = DateTime.Now; Log.Debug("WxPayApi", "OrderQuery request : " + xml); string response = HttpService.Post(xml, url, false, 6);//调用HTTP通信接口提交数据 Log.Debug("WxPayApi", "OrderQuery response : " + response); var end = DateTime.Now; int timeCost = (int)((end - start).TotalMilliseconds);//获得接口耗时 //将xml格式的数据转化为对象以返回 WxPayData result = new WxPayData(); result.FromXml(response); ReportCostTime(url, timeCost, result);//测速上报 return(result); }