사전 준비:
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();여기에서 초기화된 JsApiPay() 클래스는 먼저 객체를 얻습니다. 파일은 example/ 디렉터리의 WxPay.JsApiPay.php에 해당합니다. GetOpenid() 메서드를 호출하면 자동으로 자체 openID를 얻습니다. (2) 통합 주문
//②、统一下单 $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);주문 정보 및 결제 콜백 기능을 구성하는 WxPay.Api.php의 24행에 있는 UnifiedOrder() 메소드에 해당합니다. 여기에서 몇 가지 매개변수를 수정해야 합니다. A. :
$input->SetBody("test");B. 주문번호
$input->SetOut_trade_no(WxPayConfig::MCHID.date("YmdHis"));C. 결제 금액
$input->SetTotal_fee("1");D. 결제 확인 링크는 inform.php 파일 위치로 설정되어 있으므로 http://xy로 설정했습니다. chuyin.ren /weixinopen/wxpay/example/notify.php다른 주소도 쓸 수 있습니다. 물론 결제 승인 도메인 이름에 있어야 하며, 결제가 성공한 후에는 자동으로 지정된 방법으로 콜백됩니다. 링크를 통해 판단 및 데이터베이스 작업을 수행할 수 있습니다.
$input->SetNotify_url("http://paysdk.weixin.qq.com/example/notify.php");E. 추가 매개변수
$input->SetAttach("test");추가 매개변수는 입력할 수도 있고 입력하지 않을 수도 있습니다. 입력할 경우 문자열에 공백을 두지 않는 것이 좋습니다. 이때 결제를 클릭하시면 결제가 성공됩니다. (3) 결제 시작
<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>Pay Now 버튼을 클릭하여 callpay() 함수를 호출하면 jsApiCall() 함수가 호출되어 결제 프로그램이 열립니다.
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);다음을 따르세요. WxPay.Notify.php 클래스 파일의 Handle() 함수로 이동하세요.
/** * * 回调入口 * @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); }The $xml=$GLOBALS['HTTP_RAW_POST_DATA'] 여기에 반환된 결과는 다음과 같습니다. 결제가 성공한 후 사용자가 제공하는 문자열입니다. xml 형식입니다.
여기에 반환된 xml 데이터를 기록하고 열어서 확인할 수 있습니다. $out_trade_no는 결제 전 설정한 주문 번호이고, $attach는 추가 매개변수 설정입니다.
주문번호를 받은 뒤 데이터베이스의 데이터 변경 등 결제 성공 후 로직을 바로 아래에 작성했습니다.
이렇게 WeChat 결제의 JsApi 결제를 대략적으로 분석합니다.
위 내용은 PHP WeChat 결제 프로세스는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!