>  기사  >  백엔드 개발  >  WeChat 환불 신청 프로세스를 구현하는 PHP 방법

WeChat 환불 신청 프로세스를 구현하는 PHP 방법

不言
不言원래의
2018-06-08 16:46:111871검색

이 글에서는 WeChat 환불 신청 프로세스의 PHP 구현을 소개합니다. 공식 SDK에서 가장 중요한 클래스 파일인 WxPay.Api.php에서 제공되는 Refund() 메소드를 사용하여 구현됩니다. 이 글의 전체 내용을 참조하세요.

이전에 WeChat 결제 구현 방법에 대해 자세히 알아보려면 PHP에서 WeChat 결제(jsapi Payment) 프로세스 구현 및 ThinkPHP에서 WeChat 결제(jsapi Payment) 프로세스 구현을 참조하세요. 비즈니스 요구로 인해 WeChat 환불도 필요합니다. 조사 및 조사 끝에 마침내 해결되었습니다.

사전 준비사항:

물론 위챗 결제는 완료되었습니다. 그렇지 않으면 어떻게 환불을 받을 수 있나요? 이번에는 공식 데모를 사용해 보겠습니다. 물론 데모 자체를 다시 작성하고 캡슐화한 마스터가 인터넷에 많이 있을 수 있으므로 사용하기 쉽고 간단할 수 있지만 다음과 같은 이유로 여전히 사용을 권장하지 않습니다.

(1) 그럴 수도 있습니다. 완전한 기능은 아니지만 WeChat 결제만 구현할 수도 있지만 환불 신청, 환불 문의, 주문 취소와 같은 비즈니스 기능은 나중에 마스터 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를 통합하여 구현됩니다. 사용하기가 더 간단할 수 있습니다. 방법은 다음을 참조하세요. PHP는 WeChat 결제(jsapi 결제) 및 환불을 구현합니다(결제 SDK 통합 필요 없음)

위 내용은 이 기사의 전체 내용이므로 도움이 되기를 바랍니다. 모두의 학습을 위해, 더 많은 관련 내용을 보려면 PHP에 주목하세요. 중국어 웹사이트!

관련 권장 사항:

WeChat 미니 프로그램에서 PHP 백엔드 양식 제출

thinkPHP WeChat 공유 인터페이스 JSSDK 사용 분석

위 내용은 WeChat 환불 신청 프로세스를 구현하는 PHP 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.