이번에는 PHP로 WeChat 결제를 구현하는 방법을 보여드리겠습니다. PHP에서 WeChat 결제를 구현하는 데 있어 주의사항은 무엇인가요? 아래에서 실제 사례를 살펴보겠습니다.
최근 위챗 결제 관련 프로젝트를 접하게 되었어요. 오랫동안 위챗을 개발해왔지만, 공개 계정을 만들어 빨간 봉투를 보내본 적도 있어요. , 나는 그들의 블로그 게시물을 읽고 많은 우회를했다고 알려주었습니다.
준비:
1. WeChat 인증 서비스 계정 및 WeChat 결제 활성화
2. 다운로드 주소: 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.demo파일 처리
(1) 공식 데모를 다운로드합니다. 파일 이름은 WxpayAPI_php_v3입니다. 나중에 디렉토리 작성의 편의를 위해 파일 이름을 wxpay로 바꿉니다.
(2) 다음에서 WxPay를 엽니다. lib 폴더 .Api.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) 인증서 인증서 디렉터리를 열고 내부의 두 인증서를 자신의 결제 인증서로 바꿉니다.
2. 공식 계정 배경 설정
(1) 웹 페이지 승인 도메인 이름을 구성합니다. 내 도메인 이름은 (xy.chuyin.ren)입니다. (1) 결제 승인 디렉터리, 도메인 이름을 구성합니다. (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 表明前端判断的支付成功,我们可以根据这个将支付跳转到成功页面。
(4)支持成功回调
通过前端jsApiCall()函数可以监听支付结果,但是这个并不可信。确认是否支付成功还是应当通过notify.php 处理业务逻辑。前边配置好了支付验证链接SetNotify_url(),支付完成后,微信服务器会根据链接自动请求你的notify.php文件,打开这个文件,其实这个文件最主要的代码就两行:
$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); }
这里面的$xml=$GLOBALS['HTTP_RAW_POST_DATA'],就是支付成功后用户返回给你的一个结果,他是一个xml格式的字符串。
我们可以将这里返回的xml数据记录下来,然后打开看看$out_trade_no就是在支付之前我自己设置的订单号码,$attach就是设置的附加参数。
得到了这个订单号,然后我就直接在下面写支付成功后的逻辑了,比如改变数据库中的数据等等。
这样 微信支付的 JsApi支付就大致分析完成了。
这是集成了官方的SDK实现的,如果不使用SDK,可以使用更简单的方法,见:PHP实现微信支付(jsapi支付)和退款(无需集成支付SDK)
相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!
推荐阅读:
위 내용은 PHP로 WeChat 결제를 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!