앞서 위챗 결제 구현 방법에 대해 이야기했는데 자세한 내용은 관련 글을 참고해주세요: PHP는 위챗 결제(jsapi 결제) 프로세스를 구현합니다 그리고 ThinkPHP는 위챗 결제(jsapi 결제)를 구현합니다 ) 프로세스# 🎜🎜#. 비즈니스 요구로 인해 WeChat 환불도 필요합니다. 조사 및 탐색 끝에 마침내 해결되었습니다.
조기 준비:
물론 WeChat 결제는 완료되었습니다. 그렇지 않으면 환불 방법은 이번에도 공식 데모를 사용합니다. 물론 데모 자체를 다시 작성하고 캡슐화한 마스터가 인터넷에 많이 있을 수 있으므로 사용하기 쉽고 간단할 수 있지만 여전히 다음과 같은 이유로 사용을 권장하지 않습니다.#🎜🎜 # (1) 제대로 작동하지 않거나 WeChat Pay를 방금 구현했을 수도 있지만 나중에 필요할 수 있는 환불 신청, 환불 조회, 주문 조회, 주문 취소 등의 비즈니스 기능도 있습니다. 마스터의 SDK의 편리함에 의존하면 새로운 비즈니스 요구 사항이 있으면 혼란스러울 것입니다.
(2) 보안 고려사항, 결제 및 자금에 있어서는 매우 안전해야 합니다. 공식 SDK에 대해서도 불만이 있지만 적어도 상대적으로 안전할 것입니다. 당분간은 문제가 발견되지 않았지만 허점이 있으면 나쁠 것입니다.
이 글에서는 공식 SDK의 가장 중요한 클래스 파일인 WxPay.Api.php에서 제공하는 Refund() 메서드를 여전히 사용하고 있습니다. 이 메서드는 WxPay.Api.php 파일 141번에 구현되어 있습니다. , 코드는 다음과 같습니다.
/** * * 申请退款,WxPayRefund中out_trade_no、transaction_id至少填一个且 * out_refund_no、total_fee、refund_fee、op_user_id为必填参数 * appid、mchid、spbill_create_ip、nonce_str不需要填入 * @param WxPayRefund $inputObj * @param int $timeOut * @throws WxPayException * @return 成功时返回,其他抛异常 */ public static function refund($inputObj, $timeOut = 6){ $url = "https://api.mch.weixin.qq.com/secapi/pay/refund"; //检测必填参数 if(!$inputObj->IsOut_trade_noSet() && !$inputObj->IsTransaction_idSet()) { throw new WxPayException("退款申请接口中,out_trade_no、transaction_id至少填一个!"); }else if(!$inputObj->IsOut_refund_noSet()){ throw new WxPayException("退款申请接口中,缺少必填参数out_refund_no!"); }else if(!$inputObj->IsTotal_feeSet()){ throw new WxPayException("退款申请接口中,缺少必填参数total_fee!"); }else if(!$inputObj->IsRefund_feeSet()){ throw new WxPayException("退款申请接口中,缺少必填参数refund_fee!"); }else if(!$inputObj->IsOp_user_idSet()){ throw new WxPayException("退款申请接口中,缺少必填参数op_user_id!"); } $inputObj->SetAppid(WxPayConfig::APPID);//公众账号ID $inputObj->SetMch_id(WxPayConfig::MCHID);//商户号 $inputObj->SetNonce_str(self::getNonceStr());//随机字符串 $inputObj->SetSign();//签名 $xml = $inputObj->ToXml(); $startTimeStamp = self::getMillisecond();//请求开始时间 $response = self::postXmlCurl($xml, $url, true, $timeOut); $result = WxPayResults::Init($response); self::reportCostTime($url, $startTimeStamp, $result);//上报请求花费时间 return $result; }
공식 메서드에는 어떤 매개변수가 필요한지 명확하게 명시되어 있으며 SDK에서 일부 필수 매개변수를 채워 주었습니다. 편의를 위해 이 메서드를 다시 캡슐화하겠습니다. 프로젝트에서:
/** * 微信退款 * @param string $order_id 订单ID * @return 成功时返回(array类型),其他抛异常 */ function wxRefund($order_id){ //我的SDK放在项目根目录下的Api目录下 require_once APP_ROOT."/Api/wxpay/lib/WxPay.Api.php"; //查询订单,根据订单里边的数据进行退款 $order = M('order')->where(array('id'=>$order_id,'is_refund'=>2,'order_status'=>1))->find(); $merchid = WxPayConfig::MCHID; if(!$order) return false; $input = new WxPayRefund(); $input->SetOut_trade_no($order['order_sn']);//自己的订单号 $input->SetTransaction_id($order['transaction_id']); //微信官方生成的订单流水号,在支付成功中有返回 $input->SetOut_refund_no(getrand_num(true));//退款单号 $input->SetTotal_fee($order['total_price']);//订单标价金额,单位为分 $input->SetRefund_fee($order['total_price']);//退款总金额,订单总金额,单位为分,只能为整数 $input->SetOp_user_id($merchid); $result = WxPayApi::refund($input);//退款操作 // 这句file_put_contents是用来查看服务器返回的退款结果 测试完可以删除了 //file_put_contents(APP_ROOT.'/Api/wxpay/logs/log3.txt',arrayToXml($result),FILE_APPEND); return $result; }
여기서 불평해야 할 부분이 있는데, 지불할 때 XML 데이터가 반환되는데 여기서는 배열입니다. 가드님, 하하. 직접 판단하고 처리할 수 있는 배열을 반환하는 것이 낫습니다.
메서드 호출은 더욱 간단합니다.
//微信退款 $result = wxRefund($order_id); // 这句file_put_contents是用来查看服务器返回的退款结果 测试完可以删除了 //file_put_contents(APP_ROOT.'/Api/wxpay/logs/log4.txt',arrayToXml($result),FILE_APPEND); if(($result['return_code']=='SUCCESS') && ($result['result_code']=='SUCCESS')){ //退款成功 }else if(($result['return_code']=='FAIL') || ($result['result_code']=='FAIL')){ //退款失败 //原因 $reason = (empty($result['err_code_des'])?$result['return_msg']:$result['err_code_des']); }else{ //失败 }
성공적인 환불은 다음과 같이 반환됩니다.
# 🎜🎜# 개인 테스트가 맞습니다: 공식 SDK를 통합하여 구현됩니다. SDK를 사용하지 않는 경우 더 간단한 방법을 사용할 수 있습니다. PHP를 사용하여 WeChat 결제(jsapi 결제) 및 환불 구현(통합 필요 없음) 결제 SDK) # 🎜🎜#
PHP 관련 지식을 더 보려면PHPTutorial을 방문하세요!
위 내용은 PHP로 WeChat 환불 애플리케이션을 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!