退款申请的接口如下。
https:// api.mch.weixin.qq.com/secapi/pay/refund
退款申请时,POST数据示例如下。
<xml> <appid>wx2421b1c4370ec43b</appid> <mch_id>10000100</mch_id> <nonce_str>6cefdb308e1e2e8aabd48cf79e546a02</nonce_str> <op_user_id>10000100</op_user_id> <out_refund_no>1415701182</out_refund_no> <out_trade_no>1415757673</out_trade_no> <refund_fee>1</refund_fee> <total_fee>1</total_fee> <transaction_id></transaction_id> <sign>FE56DD4AA85C0EECA82C35595A69E153</sign></xml>
退款时需要带上证书。
上述数据的参数说明如表17-18所示。
表17-18 退款申请接口的参数说明
正确创建时,返回的数据示例如下。
<xml> <return_code><![CDATA[SUCCESS]]></return_code> <return_msg><![CDATA[OK]]></return_msg> <appid><![CDATA[wx2421b1c4370ec43b]]></appid> <mch_id><![CDATA[10000100]]></mch_id> <nonce_str><![CDATA[NfsMFbUFpdbEhPXP]]></nonce_str> <sign><![CDATA[B7274EB9F8925EB93100DD2085FA56C0]]></sign> <result_code><![CDATA[SUCCESS]]></result_code> <transaction_id><![CDATA[1008450740201411110005820873]]></transaction_id> <out_trade_no><![CDATA[1415757673]]></out_trade_no> <out_refund_no><![CDATA[1415701182]]></out_refund_no> <refund_id><![CDATA[2008450740201411110000174436]]></refund_id> <refund_channel><![CDATA]></refund_channel> <refund_fee>1</refund_fee> </xml>
上述数据的参数说明如表17-19所示。
表17-19 退款申请接口返回参数说明
退款申请接口类的实现代码如下。
1 /** 2 * 退款申请接口 3 */ 4 class Refund_pub extends Wxpay_client_pub 5 { 6 7 function __construct { 8 // 设置接口链接 9 $this->url = "https:// api.mch.weixin.qq.com/secapi/pay/refund";10 // 设置curl超时时间11 $this->curl_timeout = WxPayConf_pub::CURL_TIMEOUT;12 }13 14 /**15 * 生成接口参数XML16 */17 function createXml18 {19 try20 {21 // 检测必填参数22 if($this->parameters["out_trade_no"] == null && $this->parameters["tran- saction_id"] == null) {23 throw new SDKRuntimeException("退款申请接口中,out_trade_no、transaction_ id至少填一个!"."<br>");24 }elseif($this->parameters["out_refund_no"] == null){25 throw new SDKRuntimeException("退款申请接口中,缺少必填参数out_refund_ no!"."<br>");26 }elseif($this->parameters["total_fee"] == null){27 throw new SDKRuntimeException("退款申请接口中,缺少必填参数total_fee!". "<br>");28 }elseif($this->parameters["refund_fee"] == null){29 throw new SDKRuntimeException("退款申请接口中,缺少必填参数refund_fee!". "<br>");30 }elseif($this->parameters["op_user_id"] == null){31 throw new SDKRuntimeException("退款申请接口中,缺少必填参数op_user_id!". "<br>");32 }33 $this->parameters["appid"] = WxPayConf_pub::APPID;// 公众账号ID34 $this->parameters["mch_id"] = WxPayConf_pub::MCHID;// 商户号35 $this->parameters["nonce_str"] = $this->createNoncestr;// 随机字符串36 $this->parameters["sign"] = $this->getSign($this->parameters);// 签名37 return $this->arrayToXml($this->parameters);38 }catch (SDKRuntimeException $e)39 {40 die($e->errorMessage);41 }42 }43 /**44 * 作用:获取结果,使用证书通信45 */46 function getResult47 {48 $this->postXmlSSL;49 $this->result = $this->xmlToArray($this->response);50 return $this->result;51 }52 }