ThinkPHP框架整合微信支付之JSAPI模式圖文詳解
本文實例講述了ThinkPHP框架整合微信支付之JSAPI模式。分享給大家供大家參考,具體如下:
目前微信是很火的,微信支付目前很少在網(wǎng)上能看到一系列詳細的demo,因此,花一點時間來做一下關于微信支付系列教程,
本次教程是JSAPI模式支付,其他的還會繼續(xù)寫下去
首先,下載微信支付的demo,我們根據(jù)微信上的demo來整合到TP中。
介紹下我們這里需要用到的幾個文件:

在demo文件夾中:
js_api_call.php:提供了微信jsapi的主要功能
log_.php:提供打印日志功能
notify_url.php:異步通知功能
notify_url.log:異步通知日志
qrcode.js:生成二維碼js插件
接下來介紹下WxPayPubHelper文件夾下的文件:

cacert 文件夾是存放微信證書的(PS:具體我還沒怎么用證書,雖然下載下來了,證書請在微信商戶平臺上下載)
SDKRuntimeException.php:這個就是處理異常的、
WxPay.pub.config.php:這個是做一些配置的,稍后會詳細講解
WxPayPubHelper.php:這個其實就是微信支付的工具類,對于初學者只要知道怎么用他里面的方法就夠了
OK,了解了微信官方提供的文件,我們就可以開始整合到TP中了,廢話不多說,這就開始!
step1:將demo中的WxPayPubHelper整個文件夾都復制到TP的Vendor目錄下,像我這樣:

step2:配置WxPay.pub.config.php文件:

這里的配置都有注釋,如果還有不懂或者配置出現(xiàn)問題可以留言提問
同時我把微信的這個配置放到了TP的config中,這一步大家可以隨意
<?php
return array(
//'配置項'=>'配置值'
define('WEB_HOST', '這是您的網(wǎng)站域名地址'),
/*微信支付配置*/
'WxPayConf_pub'=>array(
'APPID' => '您的APPID',
'MCHID' => '您的商戶ID',
'KEY' => '商戶秘鑰',
'APPSECRET' => '您的APPSECRET',
'JS_API_CALL_URL' => WEB_HOST.'/index.php/Home/WxJsAPI/jsApiCall',
'SSLCERT_PATH' => WEB_HOST.'/ThinkPHP/Library/Vendor/WxPayPubHelper/cacert/apiclient_cert.pem',
'SSLKEY_PATH' => WEB_HOST.'/ThinkPHP/Library/Vendor/WxPayPubHelper/cacert/apiclient_key.pem',
'NOTIFY_URL' => WEB_HOST.'/index.php/Home/WxJsAPI/notify',
'CURL_TIMEOUT' => 30
)
);
step3:將生成二維碼的js放在Public目錄下(這里目前用不到,在用掃碼支付的情況才用到這個js),將日志文件放在Public目錄下:像我這樣:

step4:創(chuàng)建控制器:這里創(chuàng)建了一個WxJsAPIController的控制器,這里大家隨便起名字,只要這個跟你們在公眾平臺上的設置相對應就可以(公眾平臺設置稍后介紹)

下面是控制器的代碼部分了,首先初始化控制器,將WxPayPubHelper導入
/**
* 初始化
*/
public function _initialize()
{
//引入WxPayPubHelper
vendor('WxPayPubHelper.WxPayPubHelper');
}
接下來是使用統(tǒng)一支付接口,獲取prepay_id的方法:
public function jsApiCall()
{
//使用jsapi接口
$jsApi = new \JsApi_pub();
//=========步驟1:網(wǎng)頁授權獲取用戶openid============
//通過code獲得openid
if (!isset($_GET['code']))
{
//觸發(fā)微信返回code碼
$url = $jsApi->createOauthUrlForCode(C('WxPayConf_pub.JS_API_CALL_URL'));
Header("Location: $url");
}else
{
//獲取code碼,以獲取openid
$code = $_GET['code'];
$jsApi->setCode($code);
$openid = $jsApi->getOpenId();
}
//=========步驟2:使用統(tǒng)一支付接口,獲取prepay_id============
//使用統(tǒng)一支付接口
$unifiedOrder = new \UnifiedOrder_pub();
//設置統(tǒng)一支付接口參數(shù)
//設置必填參數(shù)
//appid已填,商戶無需重復填寫
//mch_id已填,商戶無需重復填寫
//noncestr已填,商戶無需重復填寫
//spbill_create_ip已填,商戶無需重復填寫
//sign已填,商戶無需重復填寫
$unifiedOrder->setParameter("openid",$openid);//商品描述
$unifiedOrder->setParameter("body","貢獻一分錢");//商品描述
//自定義訂單號,此處僅作舉例
$timeStamp = time();
$out_trade_no = C('WxPayConf_pub.APPID').$timeStamp;
$unifiedOrder->setParameter("out_trade_no",$out_trade_no);//商戶訂單號
$unifiedOrder->setParameter("total_fee","1");//總金額
$unifiedOrder->setParameter("notify_url",C('WxPayConf_pub.NOTIFY_URL'));//通知地址
$unifiedOrder->setParameter("trade_type","JSAPI");//交易類型
//非必填參數(shù),商戶可根據(jù)實際情況選填
//$unifiedOrder->setParameter("sub_mch_id","XXXX");//子商戶號
//$unifiedOrder->setParameter("device_info","XXXX");//設備號
//$unifiedOrder->setParameter("attach","XXXX");//附加數(shù)據(jù)
//$unifiedOrder->setParameter("time_start","XXXX");//交易起始時間
//$unifiedOrder->setParameter("time_expire","XXXX");//交易結束時間
//$unifiedOrder->setParameter("goods_tag","XXXX");//商品標記
//$unifiedOrder->setParameter("openid","XXXX");//用戶標識
//$unifiedOrder->setParameter("product_id","XXXX");//商品ID
$prepay_id = $unifiedOrder->getPrepayId();
//=========步驟3:使用jsapi調起支付============
$jsApi->setPrepayId($prepay_id);
$jsApiParameters = $jsApi->getParameters();
$this->assign('jsApiParameters',$jsApiParameters);
$this->display('pay');
//echo $jsApiParameters;
}
這里都是復制微信demo的,改改名字罷了,沒什么其他的
接下來是異步通知方法,也是復制的微信demo上的
public function notify()
{
//使用通用通知接口
$notify = new \Notify_pub();
//存儲微信的回調
$xml = $GLOBALS['HTTP_RAW_POST_DATA'];
$notify->saveData($xml);
//驗證簽名,并回應微信。
//對后臺通知交互時,如果微信收到商戶的應答不是成功或超時,微信認為通知失敗,
//微信會通過一定的策略(如30分鐘共8次)定期重新發(fā)起通知,
//盡可能提高通知的成功率,但微信不保證通知最終能成功。
if($notify->checkSign() == FALSE){
$notify->setReturnParameter("return_code","FAIL");//返回狀態(tài)碼
$notify->setReturnParameter("return_msg","簽名失敗");//返回信息
}else{
$notify->setReturnParameter("return_code","SUCCESS");//設置返回碼
}
$returnXml = $notify->returnXml();
echo $returnXml;
//==商戶根據(jù)實際情況設置相應的處理流程,此處僅作舉例=======
//以log文件形式記錄回調信息
// $log_ = new Log_();
$log_name= __ROOT__."/Public/notify_url.log";//log文件路徑
log_result($log_name,"【接收到的notify通知】:\n".$xml."\n");
if($notify->checkSign() == TRUE)
{
if ($notify->data["return_code"] == "FAIL") {
//此處應該更新一下訂單狀態(tài),商戶自行增刪操作
log_result($log_name,"【通信出錯】:\n".$xml."\n");
}
elseif($notify->data["result_code"] == "FAIL"){
//此處應該更新一下訂單狀態(tài),商戶自行增刪操作
log_result($log_name,"【業(yè)務出錯】:\n".$xml."\n");
}
else{
//此處應該更新一下訂單狀態(tài),商戶自行增刪操作
log_result($log_name,"【支付成功】:\n".$xml."\n");
}
//商戶自行增加處理流程,
//例如:更新訂單狀態(tài)
//例如:數(shù)據(jù)庫操作
//例如:推送支付完成信息
}
}
這里我把記錄日志的類寫到了function.php中:
function log_result($file,$word)
{
$fp = fopen($file,"a");
flock($fp, LOCK_EX) ;
fwrite($fp,"執(zhí)行日期:".strftime("%Y-%m-%d-%H:%M:%S",time())."\n".$word."\n\n");
flock($fp, LOCK_UN);
fclose($fp);
}
好了 其實控制器的方法就這么多,沒什么其他的了,下面看一下頁面,直接上代碼吧:
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="content-type" content="text/html;charset=utf-8"/>
<title>微信安全支付</title>
<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);
//alert("{$jsApiParameters}");
}
);
}
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>
</head>
<body>
</br></br></br></br>
<div align="center">
<button style="width:210px; height:30px; background-color:#FE6714; border:0px #FE6714 solid; cursor: pointer; color:white; font-size:16px;" type="button" onclick="callpay()" >貢獻一下</button>
</div>
</body>
</html>
無須改動什么,直接復制就好
接下來是微信公眾平臺上的配置了,這里我遇到過問題,如果有在這里遇到問題的同學請留言,比如出現(xiàn)了access_deined或者access_notallowed等問題,這都可能是因為這里配置不對。
請看配置過程截圖:

點擊修改進入配置:

好了,可以測試了:下面是我的測試截圖:
用微信掃描二維碼

微信上點擊貢獻一下出現(xiàn)支付頁面:

到此為止,微信JSAPI支付功能就全部做好了
當然,如果你是第一次做,肯定會遇到各種問題,
如果你是新手,遇到的問題都不知道為什么,
及時你做過了再做我相信還是可能由于細節(jié)上的疏忽會出現(xiàn)問題
不過不要煩躁,耐心的去發(fā)現(xiàn)問題
有問題請留言,下面還會介紹微信掃碼支付模式一,模式二的詳細教程
微信支付教程掃碼模式一:
//www.dbjr.com.cn/article/159356.htm
微信支付教程掃碼模式二:
//www.dbjr.com.cn/article/159362.htm
微信支付教程刷卡支付:
//www.dbjr.com.cn/article/159401.htm
更多關于thinkPHP相關內容感興趣的讀者可查看本站專題:《ThinkPHP入門教程》、《thinkPHP模板操作技巧總結》、《ThinkPHP常用方法總結》、《codeigniter入門教程》、《CI(CodeIgniter)框架進階教程》、《Zend FrameWork框架入門教程》及《PHP模板技術總結》。
希望本文所述對大家基于ThinkPHP框架的PHP程序設計有所幫助。
- Thinkphp 在api開發(fā)中異常返回依然是html的解決方式
- thinkphp5框架API token身份驗證功能示例
- ThinkPHP實現(xiàn)微信支付(jsapi支付)流程教程詳解
- thinkPHP5.0框架API優(yōu)化后的友好性分析
- Thinkphp5框架ajax接口實現(xiàn)方法分析
- thinkPHP5框架接口寫法簡單示例
- ThinkPHP框架實現(xiàn)的微信支付接口開發(fā)完整示例
- thinkPHP框架實現(xiàn)的短信接口驗證碼功能示例
- thinkPHP微信分享接口JSSDK用法實例
- thinkPHP框架對接支付寶即時到賬接口回調操作示例
- ThinkPHP和UCenter接口沖突的解決方法
- thinkphp使用url請求調用ThinkApi天氣教程【圖文詳解】
相關文章
在php中設置session用memcache來存儲的方法總結
memcached提供了一個自定義的session處理器可以被用于存儲用戶session數(shù)據(jù)到memcached服務端,下面通過本文給大家介紹在php中設置session用memcache來存儲的方法總結,對php session memcache相關知識感興趣的朋友一起學習吧2016-01-01
Laravel Memcached緩存驅動的配置與應用方法分析
這篇文章主要介紹了Laravel Memcached緩存驅動的配置與應用方法,結合實例形式分析了在Laravel框架配置Memcached緩存及相關使用方法,需要的朋友可以參考下2016-10-10
Zend Framework框架實現(xiàn)類似Google搜索分頁效果
這篇文章主要介紹了Zend Framework框架實現(xiàn)類似Google搜索分頁效果,結合實例形式分析了Zend Framework框架實現(xiàn)分頁效果所涉及的基本查詢、判斷與分頁效果構造相關操作技巧,需要的朋友可以參考下2016-11-11
PHP表單數(shù)據(jù)寫入MySQL數(shù)據(jù)庫的代碼
這篇文章主要介紹了PHP表單數(shù)據(jù)寫入MySQL數(shù)據(jù)庫的相關資料非常不錯具有參考借鑒價值,需要的朋友可以參考下2016-05-05

