ThinkPHP框架實(shí)現(xiàn)的微信支付接口開發(fā)完整示例
本文實(shí)例講述了ThinkPHP框架實(shí)現(xiàn)的微信支付接口開發(fā)。分享給大家供大家參考,具體如下:
微信支付接口開發(fā)很簡(jiǎn)單我們只需要在官方申請(qǐng)權(quán)限然后參考官方的文章即可實(shí)現(xiàn)支付開發(fā)了,下面來看一個(gè)簡(jiǎn)單的例子,具體如下。
最近有個(gè)微商城做了微信支付的接口,現(xiàn)在整理一下發(fā)上來。
首先是需要有已開通微信支付接口的公眾號(hào),這個(gè)相信大家都知道,開通之后微信會(huì)發(fā)一封郵件到你的郵箱,郵件的內(nèi)容就是開發(fā)需要用到的一些接口信息了(包含賬號(hào)密碼之類的東西)。
開發(fā)步驟
一、進(jìn)入公眾號(hào)平臺(tái),先設(shè)置幾個(gè)參數(shù),包括綁定域名、設(shè)置回調(diào)地址等等。
1、在設(shè)置 -> 公眾號(hào)設(shè)置 -> 功能設(shè)置 -> 設(shè)置JS接口安全域名

2、在微信支付 -> 開發(fā)配置 -> 配置你的js支付接口,回調(diào)地址等等,正式目錄和測(cè)試目錄都可以寫上,測(cè)試目錄需要把個(gè)人微信號(hào)先添加到白名單才能使用(提醒:用TP框架的小伙伴們?cè)谔顚懼Ц妒跈?quán)目錄時(shí)可以這樣填寫:域名/index.php/控制器/,經(jīng)測(cè)試是可以通過的,微信一樣能檢測(cè)到,之前看到網(wǎng)上有人說這樣不行,可能是現(xiàn)在升級(jí)了吧,呵呵,還有一個(gè)就是域名一定要是已經(jīng)備過案的才行,如果是在本地進(jìn)行測(cè)試的小伙伴們可以使用花生殼,我不是在打廣告,個(gè)人覺得還是挺好用的)

3、在開發(fā)者中心把“網(wǎng)頁授權(quán)獲取用戶基本信息”的域名寫上自己的域名,微信登陸時(shí)需要用到的;

二、到上面一大步設(shè)置完成后就可以開始我們的開發(fā)工作了;
1、用TP的小伙伴們可以用下面的包放到tp的擴(kuò)展里,也可以自行到官網(wǎng)下載sdk包,具體目錄:ThinkPHP\Library\Vendor\,其它就可以不用管啦;
2、打開包里的WxPayPubConfig.php文件,填寫上你的微信支付的接口信息就好啦;
三、上面二大步都是配置,這一步就是寫支付類了,其實(shí)也沒什么的,復(fù)制粘貼就好了;
1、新建Wxpay控制器,當(dāng)然你也可以自己命名,訪問的名稱要跟你在微信上配置的授權(quán)目錄一樣就好了;點(diǎn)擊這里下載Wxpay
2、代碼的地方就不多說了,下面直接上代碼;
<?php
namespace Home\Controller;
use Think\Controller;
//微信支付類
class WxpayController extends Controller {
//獲取access_token過程中的跳轉(zhuǎn)uri,通過跳轉(zhuǎn)將code傳入jsapi支付頁面
public function js_api_call() {
$order_sn = I('get.order_sn', '');
if (empty($order_sn)) {
header('location:'.__ROOT__.'/');
}
vendor('Weixinpay.WxPayPubHelper');
//使用jsapi接口
$jsApi = new \JsApi_pub();
//=========步驟1:網(wǎng)頁授權(quán)獲取用戶openid============
//通過code獲得openid
if (!isset($_GET['code'])){
//觸發(fā)微信返回code碼
$url = $jsApi->createOauthUrlForCode('域名/Wxpay/js_api_call?order_sn='.$order_sn);
//$url = $jsApi->createOauthUrlForCode(\WxPayConf_pub::JS_API_CALL_URL);
Header("Location: $url");
}else{
//獲取code碼,以獲取openid
$code = $_GET['code'];
$jsApi->setCode($code);
$openid = $jsApi->getOpenId();
}
$res = array(
'order_sn' => '20150109113322',
'order_amount' => 255
);
//=========步驟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ù)填寫
$total_fee = $res['order_amount']*100;
//$total_fee = 1;
$body = "訂單支付{$res['order_sn']}";
$unifiedOrder->setParameter("openid", "$openid");//用戶標(biāo)識(shí)
$unifiedOrder->setParameter("body", $body);//商品描述
//自定義訂單號(hào),此處僅作舉例
$out_trade_no = $res['order_sn'];
$unifiedOrder->setParameter("out_trade_no", $out_trade_no);//商戶訂單號(hào)
$unifiedOrder->setParameter("total_fee", $total_fee);//總金額
//$unifiedOrder->setParameter("attach", "order_sn={$res['order_sn']}");//附加數(shù)據(jù)
$unifiedOrder->setParameter("notify_url", \WxPayConf_pub::NOTIFY_URL);//通知地址
$unifiedOrder->setParameter("trade_type", "JSAPI");//交易類型
//非必填參數(shù),商戶可根據(jù)實(shí)際情況選填
//$unifiedOrder->setParameter("sub_mch_id","XXXX");//子商戶號(hào)
//$unifiedOrder->setParameter("device_info","XXXX");//設(shè)備號(hào)
//$unifiedOrder->setParameter("attach","XXXX");//附加數(shù)據(jù)
//$unifiedOrder->setParameter("time_start","XXXX");//交易起始時(shí)間
//$unifiedOrder->setParameter("time_expire","XXXX");//交易結(jié)束時(shí)間
//$unifiedOrder->setParameter("goods_tag","XXXX");//商品標(biāo)記
//$unifiedOrder->setParameter("openid","XXXX");//用戶標(biāo)識(shí)
//$unifiedOrder->setParameter("product_id","XXXX");//商品ID
$prepay_id = $unifiedOrder->getPrepayId();
//=========步驟3:使用jsapi調(diào)起支付============
$jsApi->setPrepayId($prepay_id);
$jsApiParameters = $jsApi->getParameters();
$wxconf = json_decode($jsApiParameters, true);
if ($wxconf['package'] == 'prepay_id=') {
$this->error('當(dāng)前訂單存在異常,不能使用支付');
}
$this->assign('res', $res);
$this->assign('jsApiParameters', $jsApiParameters);
$this->display('jsapi');
}
//異步通知url,商戶根據(jù)實(shí)際開發(fā)過程設(shè)定
public function notify_url() {
vendor('Weixinpay.WxPayPubHelper');
//使用通用通知接口
$notify = new \Notify_pub();
//存儲(chǔ)微信的回調(diào)
$xml = $GLOBALS['HTTP_RAW_POST_DATA'];
$notify->saveData($xml);
//驗(yàn)證簽名,并回應(yīng)微信。
//對(duì)后臺(tái)通知交互時(shí),如果微信收到商戶的應(yīng)答不是成功或超時(shí),微信認(rèn)為通知失敗,
//微信會(huì)通過一定的策略(如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();
//==商戶根據(jù)實(shí)際情況設(shè)置相應(yīng)的處理流程,此處僅作舉例=======
//以log文件形式記錄回調(diào)信息
//$log_name = "notify_url.log";//log文件路徑
//$this->log_result($log_name, "【接收到的notify通知】:\n".$xml."\n");
$parameter = $notify->xmlToArray($xml);
//$this->log_result($log_name, "【接收到的notify通知】:\n".$parameter."\n");
if($notify->checkSign() == TRUE){
if ($notify->data["return_code"] == "FAIL") {
//此處應(yīng)該更新一下訂單狀態(tài),商戶自行增刪操作
//$this->log_result($log_name, "【通信出錯(cuò)】:\n".$xml."\n");
//更新訂單數(shù)據(jù)【通信出錯(cuò)】設(shè)為無效訂單
echo 'error';
}
else if($notify->data["result_code"] == "FAIL"){
//此處應(yīng)該更新一下訂單狀態(tài),商戶自行增刪操作
//$this->log_result($log_name, "【業(yè)務(wù)出錯(cuò)】:\n".$xml."\n");
//更新訂單數(shù)據(jù)【通信出錯(cuò)】設(shè)為無效訂單
echo 'error';
}
else{
//$this->log_result($log_name, "【支付成功】:\n".$xml."\n");
//我這里用到一個(gè)process方法,成功返回?cái)?shù)據(jù)后處理,返回地?cái)?shù)據(jù)具體可以參考微信的文檔
if ($this->process($parameter)) {
//處理成功后輸出success,微信就不會(huì)再下發(fā)請(qǐng)求了
echo 'success';
}else {
//沒有處理成功,微信會(huì)間隔的發(fā)送請(qǐng)求
echo 'error';
}
}
}
}
//訂單處理
private function process($parameter) {
//此處應(yīng)該更新一下訂單狀態(tài),商戶自行增刪操作
/*
* 返回的數(shù)據(jù)最少有以下幾個(gè)
* $parameter = array(
'out_trade_no' => xxx,//商戶訂單號(hào)
'total_fee' => XXXX,//支付金額
'openid' => XXxxx,//付款的用戶ID
);
*/
return true;
}
}
?>
四、以上就是微信支付的整個(gè)流程了,掃碼支付的應(yīng)該都差不多,我沒去弄了,用過的朋友也可以分享下,^_^;來上幾張支付的截圖

更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP微信開發(fā)技巧匯總》、《php curl用法總結(jié)》、《PHP網(wǎng)絡(luò)編程技巧總結(jié)》、《php字符串(string)用法總結(jié)》、《PHP中json格式數(shù)據(jù)操作技巧匯總》及《PHP針對(duì)XML文件操作技巧總結(jié)》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
- 微信小程序開發(fā)之獲取用戶手機(jī)號(hào)碼(php接口解密)
- php獲取微信基礎(chǔ)接口憑證Access_token
- PHP封裝的微信公眾平臺(tái)接口開發(fā)操作類完整示例
- thinkPHP微信分享接口JSSDK用法實(shí)例
- 詳解使用php調(diào)用微信接口上傳永久素材
- PHP實(shí)現(xiàn)微信JS-SDK接口選擇相冊(cè)及拍照并上傳的方法
- php微信高級(jí)接口調(diào)用方法(自定義菜單接口、客服接口、二維碼)
- PHP配合微信小程序?qū)崿F(xiàn)獲取手機(jī)號(hào)碼詳解
- 微信小程序結(jié)合ThinkPHP5授權(quán)登陸后獲取手機(jī)號(hào)
- PHP請(qǐng)求微信接口獲取用戶電話號(hào)功能示例
相關(guān)文章
如何動(dòng)態(tài)查看及加載PHP擴(kuò)展
這篇文章主要介紹了如何動(dòng)態(tài)查看及加載PHP擴(kuò)展,幫助大家更好的理解和學(xué)習(xí)使用PHP,感興趣的朋友可以了解下2021-04-04
php實(shí)現(xiàn)HTML實(shí)體編號(hào)與非ASCII字符串相互轉(zhuǎn)換類實(shí)例
本篇文章主要介紹了"php實(shí)現(xiàn)HTML實(shí)體編號(hào)與非ASCII字符串相互轉(zhuǎn)換類實(shí)例",主要涉及到HTML實(shí)體編號(hào)與非ASCII字符串相互轉(zhuǎn)換類方面的內(nèi)容,感興趣的同學(xué)可以參考一下。2016-11-11
PHP實(shí)現(xiàn)微信小程序用戶授權(quán)的工具類示例
這篇文章主要介紹了PHP實(shí)現(xiàn)微信小程序用戶授權(quán)的工具類示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03
Thinkphp集成抖音SDK的實(shí)現(xiàn)方法
這篇文章主要介紹了Thinkphp集成抖音SDK的實(shí)現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04
JSON PHP中,Json字符串反序列化成對(duì)象/數(shù)組的方法
今天小編就為大家分享一篇JSON PHP中,Json字符串反序列化成對(duì)象/數(shù)組的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-05-05

