PHP實現微信支付實戰案例詳解

來源:互聯網
上載者:User
這次給大家帶來PHP實現支付實戰案例詳解,PHP實現支付的注意事項有哪些,下面就是實戰案例,一起來看一下。

前期準備:

1.認證服務號,並且開通了支付

2.支付SDK,下載地址:https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=11_1

3.登入支付平台https://pay.weixin.qq.com/index.php/account/api_cert下載支付認證

方法步驟:

1.demo檔案處理

(1)將官方的demo下載下來,檔案名稱為WxpayAPI_php_v3,把這檔案重新命名為wxpay,為了後邊書寫目錄方便;

(2)開啟lib檔案夾下的WxPay.Api.php檔案,在537行有一段curl網路請求配置代碼:

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 驗證對等認證(peer's certificate)。

(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)開啟cert認證目錄,將裡邊的兩個認證換成自己的支付認證。

2.公眾號後台設定

(1)配置網頁授權網域名稱,我的網域名稱是(xy.chuyin.ren);

(1)配置支付授權目錄,網域名稱是(xy.chuyin.ren),我將demo放到此網域名稱指向的目錄的weixinopen/檔案夾下,demo中jsapi.php檔案位於example/目錄下,所以支付授權目錄為:xy.chuyin.ren/weixinopen/wxpay/example/

3.支付流程

開啟example目錄下的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. 支付驗證鏈結接

設定為你的notify.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>

點擊立即支付按鈕調用的就是 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回呼函數與匿名函數使用案例解析

PHP使用函數靜態變數實現指定迭代次數步驟詳解

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.