/** * * 查询退款 * 提交退款申请后,通过调用该接口查询退款状态。退款有一定延时, * 用零钱支付的退款20分钟内到账,银行卡支付的退款3个工作日后重新查询退款状态。 * RefundQuery中out_refund_no、out_trade_no、transaction_id、refund_id四个参数必填一个 * appid、mchid、spbill_create_ip、nonce_str不需要填入 * @param RefundQuery $inputObj * @param int $timeOut * @throws Exception * @return 成功时返回,其他抛异常 */ public static function refundQuery($inputObj, $timeOut = 6) { $url = "https://api.mch.weixin.qq.com/pay/refundquery"; //检测必填参数 if (!$inputObj->IsOut_refund_noSet() && !$inputObj->IsOut_trade_noSet() && !$inputObj->IsTransaction_idSet() && !$inputObj->IsRefund_idSet()) { throw new Exception("退款查询接口中,out_refund_no、out_trade_no、transaction_id、refund_id四个参数必填一个!"); } $inputObj->SetAppid(Config::APPID); //公众账号ID $inputObj->SetMch_id(Config::MCHID); //商户号 $inputObj->SetNonce_str(self::getNonceStr()); //随机字符串 $inputObj->SetSign(); //签名 $xml = $inputObj->ToXml(); $startTimeStamp = self::getMillisecond(); //请求开始时间 $response = self::postXmlCurl($xml, $url, false, $timeOut); $result = Results::Init($response); self::reportCostTime($url, $startTimeStamp, $result); //上报请求花费时间 return $result; }
<?php /** * 退款申请接口-demo * ==================================================== * * */ include_once "./WxPayHelper/WxPayHelper.php"; //要查询的订单号 if (!isset($_POST["out_trade_no"])) { $out_trade_no = " "; } else { $out_trade_no = $_POST["out_trade_no"]; //使用退款查询接口 $refundQuery = new RefundQuery(); //设置必填参数 //appid已填,商户无需重复填写 //mch_id已填,商户无需重复填写 //noncestr已填,商户无需重复填写 //sign已填,商户无需重复填写 $refundQuery->setParameter("out_trade_no", "{$out_trade_no}"); //商户订单号 // $refundQuery->setParameter("out_refund_no","XXXX");//商户退款单号 // $refundQuery->setParameter("refund_id","XXXX");//微信退款单号 // $refundQuery->setParameter("transaction_id","XXXX");//微信退款单号 //非必填参数,商户可根据实际情况选填 //$refundQuery->setParameter("sub_mch_id","XXXX");//子商户号 //$refundQuery->setParameter("device_info","XXXX");//设备号 //退款查询接口结果 $refundQueryResult = $refundQuery->getResult(); //商户根据实际情况设置相应的处理流程,此处仅作举例