사전 준비:
1. WeChat 인증 서비스 계정 및 WeChat 결제 활성화
2. WeChat 결제 SDK 다운로드 주소: https://pay.weixin.qq.com/wiki/doc /api/jsapi.php?chapter=11_1
3. WeChat 결제 플랫폼 https://pay.weixin.qq.com/index.php/account/api_cert에 로그인하여 결제 인증서를 다운로드하세요.
방법 단계 :
1. 데모 파일 처리
(1) 공식 데모를 다운로드합니다. 파일 이름은 WxpayAPI_php_v3입니다. 나중에 디렉토리 작성의 편의를 위해 이 파일의 이름을 wxpay로 바꿉니다.
(2) 다음에서 WxPay.Api를 엽니다. lib 폴더 .php 파일에는 537행에 컬 네트워크 요청 구성 코드가 있습니다.
curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,TRUE); curl_setopt($ch,CURLOPT_SSL_VERIFYHOST,2);//严格校验
는
curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,FALSE); curl_setopt($ch,CURLOPT_SSL_VERIFYHOST,2);//严格校验
로 대체되어 cURL이 피어 인증서를 확인하지 못하도록 합니다.
(3) lib 폴더 아래의 WxPay.Config.php 파일을 엽니다. 25번째 줄부터 계정에 따라 기본 정보 설정을 완료합니다.
const APPID = '公众账号APPID'; const MCHID = '商户号'; const KEY = '商户支付密钥'; const APPSECRET = '公众帐号secert';
(4) lib 아래의 WxPay.Notify.php 파일을 엽니다. 폴더, 79행의 코드:
if($needSign == true && $this->GetReturn_code($return_code) == "SUCCESS") { $this->SetSign(); }
는 다음과 같이 변경됩니다.
if($needSign == true && $this->GetReturn_code() == "SUCCESS") { $this->SetSign(); }
(5) 인증서 인증서 디렉터리를 열고 내부의 두 인증서를 자신의 결제 인증서로 바꿉니다.
관련 권장 사항: "PHP 튜토리얼"
2. 공개 계정 배경 설정
(1) 웹 페이지 승인 도메인 이름을 구성합니다. 내 도메인 이름은 (xy.chuyin.ren)입니다. 2) 구성 결제 승인 디렉터리, 도메인 이름은 (xy.chuyin.ren), 이 도메인 이름이 가리키는 디렉터리의 weixinopen/ 폴더에 데모를 넣었습니다. 데모의 jsapi.php 파일은 다음 위치에 있습니다. example/ 디렉터리이므로 결제 승인 디렉터리는 다음과 같습니다. xy .chuyin.ren/weixinopen/wxpay/example/
3. 결제 프로세스
결제 시작에서 jsapi.php 파일을 엽니다. 여기에서 모든 처리가 완료됩니다.
(1) 사용자 openid 가져오기이전에 APPID 및 APPSecert를 구성했으므로 여기서 처리할 필요가 없습니다.//①、获取用户openid $tools = new JsApiPay(); $openId = $tools->GetOpenid();
//②、统一下单 $input = new WxPayUnifiedOrder(); $input->SetBody("test"); $input->SetAttach("test"); $input->SetOut_trade_no(WxPayConfig::MCHID.date("YmdHis")); $input->SetTotal_fee("1"); $input->SetTime_start(date("YmdHis")); $input->SetTime_expire(date("YmdHis", time() + 600)); $input->SetGoods_tag("test"); $input->SetNotify_url("http://paysdk.weixin.qq.com/example/notify.php"); $input->SetTrade_type("JSAPI"); $input->SetOpenid($openId); $order = WxPayApi::unifiedOrder($input); echo '<font color="#f00"><b>统一下单支付单信息</b></font><br/>'; printf_info($order); $jsApiParameters = $tools->GetJsApiParameters($order);
$input->SetBody("test");
$input->SetOut_trade_no(WxPayConfig::MCHID.date("YmdHis"));
$input->SetTotal_fee("1");
$input->SetNotify_url("http://paysdk.weixin.qq.com/example/notify.php");
$input->SetAttach("test");
<script type="text/javascript"> //调用微信JS api 支付 function jsApiCall() { WeixinJSBridge.invoke( 'getBrandWCPayRequest', <?php echo $jsApiParameters; ?>, function(res){ WeixinJSBridge.log(res.err_msg); alert(res.err_code+res.err_desc+res.err_msg); } ); } function callpay() { if (typeof WeixinJSBridge == "undefined"){ if( document.addEventListener ){ document.addEventListener('WeixinJSBridgeReady', jsApiCall, false); }else if (document.attachEvent){ document.attachEvent('WeixinJSBridgeReady', jsApiCall); document.attachEvent('onWeixinJSBridgeReady', jsApiCall); } }else{ jsApiCall(); } } </script>
jsApiCall() 함수는 작업의 모든 단계를 모니터링합니다.
res.err_msg는 프런트 엔드에서 판단한 결제 취소를 나타내는 get_brand_wcpay_request:cancel이고, es.err_msg는 get_brand_wcpay_request:ok를 나타내는 get_brand_wcpay_request:ok입니다. 프론트엔드에서 결제 성공 여부를 판단하면 이를 기반으로 결제 성공 페이지로 이동합니다.
(4) 성공 콜백 지원
프런트엔드 jsApiCall() 함수를 통해 결제 결과를 모니터링할 수 있지만 이는 신뢰할 수 없습니다. 결제 성공 여부를 확인하려면 inform.php를 통해 비즈니스 로직을 처리해야 한다. 결제 확인 링크 SetNotify_url()은 이전에 구성되었습니다. 결제가 완료된 후 WeChat 서버는 링크에 따라 자동으로 inform.php 파일을 요청하고 이 파일을 엽니다. 실제로 이 파일의 주요 코드는 2개뿐입니다. 줄:
$notify = new PayNotifyCallBack(); $notify->Handle(false);
/** * * 回调入口 * @param bool $needSign 是否需要签名输出 */ final public function Handle($needSign = true) { $msg = "OK"; //当返回false的时候,表示notify中调用NotifyCallBack回调失败获取签名校验失败,此时直接回复失败 $result = WxpayApi::notify(array($this, 'NotifyCallBack'), $msg); if($result == false){ $this->SetReturn_code("FAIL"); $this->SetReturn_msg($msg); $this->ReplyNotify(false); return; } else { //该分支在成功回调到NotifyCallBack方法,处理完成之后流程 $this->SetReturn_code("SUCCESS"); $this->SetReturn_msg("OK"); } $this->ReplyNotify($needSign); }
$result = WxpayApi::notify(array($this, 'NotifyCallBack'), $msg); 然后来到WxPay.Api.php文件的第411行,notify()函数: /** * * 支付结果通用通知 * @param function $callback * 直接回调函数使用方法: notify(you_function); * 回调类成员函数方法:notify(array($this, you_function)); * $callback 原型为:function function_name($data){} */ public static function notify($callback, &$msg) { //获取通知的数据 $xml = $GLOBALS['HTTP_RAW_POST_DATA']; //file_put_contents('log.txt',$xml,FILE_APPEND); //如果返回成功则验证签名 try { $result = WxPayResults::Init($xml); } catch (WxPayException $e){ $msg = $e->errorMessage(); return false; } return call_user_func($callback, $result); }
여기에 반환된 xml 데이터를 기록하고 열어서 확인할 수 있습니다. $out_trade_no는 결제 전 설정한 주문 번호이고, $attach는 추가 매개변수 설정입니다.
주문번호를 받은 뒤 데이터베이스의 데이터 변경 등 결제 성공 후 로직을 바로 아래에 작성했습니다.
이렇게 WeChat 결제의 JsApi 결제를 대략적으로 분석합니다.
위 내용은 PHP WeChat 결제 프로세스는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!