ThinkPHP框架整合微信支付之JSAPI模式圖文詳解_第1頁
ThinkPHP框架整合微信支付之JSAPI模式圖文詳解_第2頁
ThinkPHP框架整合微信支付之JSAPI模式圖文詳解_第3頁
ThinkPHP框架整合微信支付之JSAPI模式圖文詳解_第4頁
ThinkPHP框架整合微信支付之JSAPI模式圖文詳解_第5頁
已閱讀5頁,還剩6頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

第ThinkPHP框架整合微信支付之JSAPI模式圖文詳解本文實例講述了ThinkPHP框架整合微信支付之JSAPI模式。分享給大家供大家參考,具體如下:

目前微信是很火的,微信支付目前很少在網(wǎng)上能看到一系列詳細的demo,因此,花一點時間來做一下關(guān)于微信支付系列教程,

本次教程是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:這個其實就是微信支付的工具類,對于初學(xué)者只要知道怎么用他里面的方法就夠了

OK,了解了微信官方提供的文件,我們就可以開始整合到TP中了,廢話不多說,這就開始!

step1:將demo中的WxPayPubHelper整個文件夾都復(fù)制到TP的Vendor目錄下,像我這樣:

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

這里的配置都有注釋,如果還有不懂或者配置出現(xiàn)問題可以留言提問

同時我把微信的這個配置放到了TP的config中,這一步大家可以隨意

returnarray(

//'配置項'='配置值'

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的控制器,這里大家隨便起名字,只要這個跟你們在公眾平臺上的設(shè)置相對應(yīng)就可以(公眾平臺設(shè)置稍后介紹)

下面是控制器的代碼部分了,首先初始化控制器,將WxPayPubHelper導(dǎo)入

*初始化

publicfunction_initialize()

//引入WxPayPubHelper

vendor('WxPayPubHelper.WxPayPubHelper');

}

接下來是使用統(tǒng)一支付接口,獲取prepay_id的方法:

publicfunctionjsApiCall()

//使用jsapi接口

$jsApi=new\JsApi_pub();

//=========步驟1:網(wǎng)頁授權(quán)獲取用戶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();

//設(shè)置統(tǒng)一支付接口參數(shù)

//設(shè)置必填參數(shù)

//appid已填,商戶無需重復(fù)填寫

//mch_id已填,商戶無需重復(fù)填寫

//noncestr已填,商戶無需重復(fù)填寫

//spbill_create_ip已填,商戶無需重復(fù)填寫

//sign已填,商戶無需重復(fù)填寫

$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");//設(shè)備號

//$unifiedOrder-setParameter("attach","XXXX");//附加數(shù)據(jù)

//$unifiedOrder-setParameter("time_start","XXXX");//交易起始時間

//$unifiedOrder-setParameter("time_expire","XXXX");//交易結(jié)束時間

//$unifiedOrder-setParameter("goods_tag","XXXX");//商品標記

//$unifiedOrder-setParameter("openid","XXXX");//用戶標識

//$unifiedOrder-setParameter("product_id","XXXX");//商品ID

$prepay_id=$unifiedOrder-getPrepayId();

//=========步驟3:使用jsapi調(diào)起支付============

$jsApi-setPrepayId($prepay_id);

$jsApiParameters=$jsApi-getParameters();

$this-assign('jsApiParameters',$jsApiParameters);

$this-display('pay');

//echo$jsApiParameters;

}

這里都是復(fù)制微信demo的,改改名字罷了,沒什么其他的

接下來是異步通知方法,也是復(fù)制的微信demo上的

publicfunctionnotify()

//使用通用通知接口

$notify=new\Notify_pub();

//存儲微信的回調(diào)

$xml=$GLOBALS['HTTP_RAW_POST_DATA'];

$notify-saveData($xml);

//驗證簽名,并回應(yīng)微信。

//對后臺通知交互時,如果微信收到商戶的應(yīng)答不是成功或超時,微信認為通知失敗,

//微信會通過一定的策略(如30分鐘共8次)定期重新發(fā)起通知,

//盡可能提高通知的成功率,但微信不保證通知最終能成功。

if($notify-checkSign()==FALSE){

$notify-setReturnParameter("return_code","FAIL");//返回狀態(tài)碼

$notify-setReturnParameter("return_msg","簽名失敗");//返回信息

}else{

$notify-setReturnParameter("return_code","SUCCESS");//設(shè)置返回碼

$returnXml=$notify-returnXml();

echo$returnXml;

//==商戶根據(jù)實際情況設(shè)置相應(yīng)的處理流程,此處僅作舉例=======

//以log文件形式記錄回調(diào)信息

//$log_=newLog_();

$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"){

//此處應(yīng)該更新一下訂單狀態(tài),商戶自行增刪操作

log_result($log_name,"【通信出錯】:\n".$xml."\n");

elseif($notify-data["result_code"]=="FAIL"){

//此處應(yīng)該更新一下訂單狀態(tài),商戶自行增刪操作

log_result($log_name,"【業(yè)務(wù)出錯】:\n".$xml."\n");

else{

//此處應(yīng)該更新一下訂單狀態(tài),商戶自行增刪操作

log_result($log_name,"【支付成功】:\n".$xml."\n");

//商戶自行增加處理流程,

//例如:更新訂單狀態(tài)

//例如:數(shù)據(jù)庫操作

//例如:推送支付完成信息

}

這里我把記錄日志的類寫到了function.php中:

functionlog_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);

}

好了其實控制器的方法就這么多,沒什么其他的了,下面看一下頁面,直接上代碼吧:

!DOCTYPEhtml

html

head

metahttp-equiv="content-type"content="text/html;charset=utf-8"/

title微信安全支付/title

scripttype="text/javascript"

//調(diào)用微信JSapi支付

functionjsApiCall()

WeixinJSBridge.invoke(

'getBrandWCPayRequest',

phpecho$jsApiParameters;,

function(res){

WeixinJSBridge.log(res.err_msg);

alert(res.err_code+res.err_desc+res.err_msg);

//alert("{$jsApiParameters}");

functioncallpay()

if(typeofWeixinJSBridge=="undefined"){

if(document.addEventListener){

document.addEventListener('WeixinJSBridgeReady',jsApiCall,false);

}elseif(document.attachEvent){

document.attachEvent('WeixinJSBridgeReady',jsApiCall);

document.attachEvent('onWeixinJSBridgeReady',jsApiCall);

}else{

jsApiCall();

/script

/head

body

/br/br/br/br

divalign="center"

buttontype="button"貢獻一下/button

/div

/body

/html

無須改動什么,直接復(fù)制就好

接下來是微信公眾平臺上的配置了,這里我遇到過問題,如果有在這里遇到問題的同學(xué)請留言,比如出

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論