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

下載本文檔

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

文檔簡介

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

大家好,這篇文章是繼微信支付jsapi篇之后的微信支付系列教程第二篇:掃碼支付之模式一介紹下掃碼支付目前有兩種模式,模式一比模式二稍微復(fù)雜點,至于模式一與模式二的具體內(nèi)容,流程,微信開發(fā)文檔都有詳細介紹,這里就不多說廢話,接下來趕緊上教程!

首先我們還是一樣,導(dǎo)入微信支付的類庫:

接下來是Public下的文件:

這里的配置跟JSAPI支付一樣,不需要改動

具體關(guān)于文件介紹請參考JSAPI支付,這里就不再說明了鏈接地址:///article/159351.htm

接下來直接看控制器部分的代碼:

step1:同樣,先初始化引入WxPayPubHelper類庫

*初始化

*/

publicfunction_initialize()

{

//引入WxPayPubHelper

vendor('WxPayPubHelper.WxPayPubHelper');

}

step2:展示掃碼頁面需要先生存二維碼鏈接

publicfunctionnative_pay()

{

//設(shè)置靜態(tài)鏈接

$nativeLink=new\NativeLink_pub();

//設(shè)置靜態(tài)鏈接參數(shù)

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

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

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

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

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

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

$product_id=C('WxPayConf_pub.APPID')."static";//自定義商品id

$nativeLink-setParameter("product_id",$product_id);//商品id

//獲取鏈接

$product_url=$nativeLink-getUrl();

//使用短鏈接轉(zhuǎn)換接口

$shortUrl=new\ShortUrl_pub();

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

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

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

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

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

$shortUrl-setParameter("long_url",$product_url);//URL鏈接

//獲取短鏈接

$codeUrl=$shortUrl-getShortUrl();

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

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

$this-display();

}

以上代碼對應(yīng)native_pay.html頁面

!DOCTYPEHTML

html

head

metacharset="UTF-8"

title微信安全支付/title

/head

body

divalign="center"id="qrcode"

p掃我,掃我/p

/div

divalign="center"

ahref="#"rel="externalnofollow"返回首頁/a

/div

/body

scriptsrc="__PUBLIC__/js/qrcode.js"/script

script

varurl="phpecho$product_url;

//參數(shù)1表示圖像大小,取值范圍1-10;參數(shù)2表示質(zhì)量,取值范圍'L','M','Q','H'

varqr=qrcode(10,'M');

qr.addData(url);

qr.make();

vardom=document.createElement('DIV');

dom.innerHTML=qr.createImgTag();

varelement=document.getElementById("qrcode");

element.appendChild(dom);

/script

/html

這里注意生存二維碼的js地址,我放在了Public下的JS目錄下

step3:掃碼之后,就會提交給我們公眾平臺native配置的地址對應(yīng)的去方法處理公眾平臺navtive配置:配置地址http://您的域名/Pay/index.php/Home/WxNative/todoPost

對應(yīng)的todoPost方法在控制器中:

publicfunctiontodoPost()

{

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

$log_name=__ROOT__."/Public/native_call.log";

//使用native通知接口

$nativeCall=new\NativeCall_pub();

//接收微信請求

$xml=$GLOBALS['HTTP_RAW_POST_DATA'];

log_result($log_name,"【接收到的native通知】:\n".$xml."\n");

$nativeCall-saveData($xml);

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

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

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

}

else

{

//提取product_id

$product_id=$nativeCall-getProductId();

//使用統(tǒng)一支付接口

$unifiedOrder=new\UnifiedOrder_pub();

//根據(jù)不同的$product_id設(shè)定對應(yīng)的下單參數(shù),此處只舉例一種

switch($product_id)

{

caseC('WxPayConf_pub.APPID')."static"://與native_call_qrcode.php中的靜態(tài)鏈接二維碼對應(yīng)

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

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

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

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

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

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

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

$unifiedOrder-setParameter("body","貢獻一分錢");//商品描述

//自定義訂單號,此處僅作舉例

$timeStamp=time();

$out_trade_no=C('WxPayConf_pub.APPID').$timeStamp;

$unifiedOrder-setParameter("out_trade_no",$out_trade_no);//商戶訂單號$unifiedOrder-setParameter("product_id","$product_id");//商品ID

$unifiedOrder-setParameter("total_fee","1");//總金額

$unifiedOrder-setParameter("notify_url",C('WxPayConf_pub.NOTIFY_URL'));//通知地址

$unifiedOrder-setParameter("trade_type","NATIVE");//交易類型

$unifiedOrder-setParameter("product_id",$product_id);//用戶標(biāo)識

//非必填參數(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");//商品標(biāo)記

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

//獲取prepay_id

$prepay_id=$unifiedOrder-getPrepayId();

//設(shè)置返回碼

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

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

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

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

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

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

$nativeCall-setReturnParameter("result_code","SUCCESS");//業(yè)務(wù)結(jié)果

$nativeCall-setReturnParameter("prepay_id",$prepay_id);//預(yù)支付ID

break;

default:

//設(shè)置返回碼

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

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

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

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

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

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

$nativeCall-setReturnParameter("result_code","FAIL");//業(yè)務(wù)結(jié)果

$nativeCall-setReturnParameter("err_code_des","此商品無效");//業(yè)務(wù)結(jié)果

break;

}

}

//將結(jié)果返回微信

$returnXml=$nativeCall-returnXml();

log_result($log_name,"【返回微信的native響應(yīng)】:\n".$returnXml."\n");

echo$returnXml;

}

其實到這里你已經(jīng)完成了掃碼支付模式一的功能

step4:接下來寫一下異步通知處理,與jsapi支付一樣:

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文件路徑

$this-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_res

溫馨提示

  • 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. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論