當時的環境是沒有使用框架的,直接在一個域名指向的目錄下邊新建目錄之后訪問該目錄實現的,但應用到框架中,還是有一些問題,在ThinkPHP中,由于路由規則與支付授權目錄有出入,所以會報錯。本篇講講在TP中集成微信支付的流程。
鵝廠出的SDK和文檔,就是讓你看不懂,使勁繞,這酸爽用了就知道。文檔和SDK不是應該越簡單通俗易懂越好么?難道只有使勁重構才能顯示出鵝廠程序猿技術的高超咩?額...是不是暴露了我菜鳥的屬性...其實SDK蠻好用,只是上一篇文章中也看到了,在支付完成回調函數中,著實讓人繞的暈頭轉向。
對于不想被官方繞的,想在TP中使用微信支付的可以看看一個大神自己根據官方文檔重構精簡打造而成的適用于TP的支付SDK,源碼我下載下來看過了,代碼寫的很優雅簡介,流程也很簡單,通俗易懂。詳見博文:http://baijunyao.com/article/78
我自己還是皺著眉頭,使用了官方的SDK,也成功實現了支付,下面跟大家分享一下流程:
1.SDK下載和修改
這個就不過多講了,不知道的可以看看我的上一篇文章:PHP實現微信支付(jsapi支付)流程,里邊詳細詳述了下載下來的文件哪些是需要修改的。
2.公眾號設置
A. 還是需要設置網頁授權域名,這個沒啥特殊的;
B. 這里要注意一下支付授權目錄,使用TP很多人都使用的是重寫模式(REWRITE模式)或者在使用REWRITE模式的同時,使用偽靜態模式,這時候生成的鏈接為: http://serverName/Home/Blog/read/id/1 ;
如果使用的是PATHINFO模式的話,生成的鏈接就是:http://serverName/index.php/Home/Blog/read/id/1,比如在Home模塊下的Blog控制器中的某個方法進行支付,我們支付的授權目錄應該是 http://serverName/Home/Blog/ 或者 http://serverName/index.php/Home/Blog/,這個根據自己的TP的設置的URL模式而定。
3.支付流程
(1)統一下單
下單的支付參數配置,這個跟上一篇講的基本不變,重點注意的是支付回調驗證鏈接,因為要多次調用,我就直接在Application/Common/Common/function.php中將參數配置封裝起來了,我的SDK放在項目根目錄下的Api目錄下,所以引入SDK的時候不是使用Vendor函數。
/** * 微信支付 * @param string $openId openid * @param string $goods 商品名稱 * @param string $attach 附加參數,我們可以選擇傳遞一個參數,比如訂單ID * @param string $order_sn 訂單號 * @param string $total_fee 金額 */ function wxpay($openId,$goods,$order_sn,$total_fee,$attach){ require_once APP_ROOT."/Api/wxpay/lib/WxPay.Api.php"; require_once APP_ROOT."/Api/wxpay/payment/WxPay.JsApiPay.php"; require_once APP_ROOT.'/Api/wxpay/payment/log.php'; //初始化日志 $logHandler= new CLogFileHandler(APP_ROOT."/Api/wxpay/logs/".date('Y-m-d').'.log'); $log = Log::Init($logHandler, 15); $tools = new JsApiPay(); if(empty($openId)) $openId = $tools->GetOpenid(); $input = new WxPayUnifiedOrder(); $input->SetBody($goods); //商品名稱 $input->SetAttach($attach); //附加參數,可填可不填,填寫的話,里邊字符串不能出現空格 $input->SetOut_trade_no($order_sn); //訂單號 $input->SetTotal_fee($total_fee); //支付金額,單位:分 $input->SetTime_start(date("YmdHis")); //支付發起時間 $input->SetTime_expire(date("YmdHis", time() + 600));//支付超時 $input->SetGoods_tag("test3"); //$input->SetNotify_url("http://".$_SERVER['HTTP_HOST']."/payment.php"); //支付回調驗證地址 $input->SetNotify_url("http://".$_SERVER['HTTP_HOST']."/payment.php/WexinApi/WeixinPay/notify"); $input->SetTrade_type("JSAPI"); //支付類型 $input->SetOpenid($openId); //用戶openID $order = WxPayApi::unifiedOrder($input); //統一下單 $jsApiParameters = $tools->GetJsApiParameters($order); return $jsApiParameters; }
注意,注意,敲黑板劃重點了:
支付回調驗證鏈接,必須是沒有權限驗證的,如果你自己訪問那個鏈接,還需要登錄注冊驗證的,就不要嘗試了,必須要可以無障礙訪問的鏈接,而且也不要有一連串的參數傳遞。
鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。
新聞熱點
疑難解答