本文實例講述了ThinkPHP框架下整合支付寶支付功能。分享給大家供大家參考,具體如下:
背景
- 近期項目需要接入支付寶支付功能,其中開發(fā)使用了ThinkPHP3.2.3框架,通過參考開發(fā)平臺文檔可以知道,網(wǎng)站開發(fā)有兩種場景,一種是手機網(wǎng)站支付,直接喚醒支付寶app進入支付操作;另一種多是 PC 端顯示支付二維碼的形式,然后使用手機的支付寶app掃描。
- 此處主要介紹手機網(wǎng)站支付的實現(xiàn),后期補充掃碼支付。
一.接入配置
1).接入步驟
根據(jù)“快速接入”中的流程,兩者大同小異,都是進行:
- 第一步:創(chuàng)建應(yīng)用并獲取APPID
- 第二步:配置密鑰
- 第三步:搭建和配置開發(fā)環(huán)境
- 第四步:調(diào)用接口
2).配置截圖

3).提示說明
雖然官方文檔已經(jīng)做的很詳細、成熟,不過還是有幾點需要著重提醒一下,以免不必要的糾結(jié)。
- 應(yīng)用創(chuàng)建成功后需要大概一到三天的審核
- 配置密鑰時建議下載其提供的加密工具,可參考RSA密鑰生成方法
- 此處我所下載的是開發(fā)平臺服務(wù)端SDK中的PHP版資源,而非DEMO文件,相信兩者還是有所區(qū)別的
二.手機網(wǎng)站支付接口實現(xiàn)
1).測試入口頁面
如下圖所示,我在此創(chuàng)建了一個簡單的入口文件,根據(jù)開發(fā)文檔中的介紹是需要統(tǒng)一編碼格式的,此處我選擇的是UTF-8

2).html代碼參考
需要注意的是,接口指明需要POST方式進行提交請求

3).支付寶配置信息
對于支付寶的配置信息,我寫在 Application/Common/Conf/config.php中
//支付寶 支付配置
'ALI_CONFIG' => array(
'gatewayUrl' => 'https://openapi.alipay.com/gateway.do',//支付寶網(wǎng)關(guān)(固定)'
'appId' => '2017xxxxxxxx9',//APPID即創(chuàng)建應(yīng)用后生成
//由開發(fā)者自己生成: 請?zhí)顚戦_發(fā)者私鑰去頭去尾去回車,一行字符串
'rsaPrivateKey' => 'MIIExxxxxxxxxxxxxxxxxxxxxxxxxxxq',
//支付寶公鑰,由支付寶生成: 請?zhí)顚懼Ц秾毠€,一行字符串
'alipayrsaPublicKey' => 'IIBxxxxxxxxxxxxxxxxxxxEFAA',
'notifyUrl' => 'http://www.xxx.com/m/cartpay/notify_ali', // 支付成功通知地址
'returnUrl' => 'http://www.xxx.com', // 支付后跳轉(zhuǎn)地址
'returnPcUrl' => 'http://www.xxx.com/Home', // PC端掃碼支付后跳轉(zhuǎn)地址
),
4).服務(wù)端SDK導入
將前面所下載的SDK放入自定義的位置,在此,我習慣放在如下的路徑中,…\ThinkPHP\Library\Vendor\Alipay,特別提醒一點,對于各文件類的引用會依據(jù)代碼框架而不同,需要自行確認。
5).支付接口實現(xiàn)
在請求喚醒支付寶支付的路徑中進行接口代碼的編輯

提示
- 通過實驗發(fā)現(xiàn),如果在電腦端進行此功能的支付測試,會報出如下的類似錯誤,個人認為源于手機和PC的內(nèi)置配置不同
- 對于手機網(wǎng)站支付需要在手機上測試,可自行配置虛擬域名手機訪問即可,不要在此問題上花費不必要的時間
- 因為本人就是在電腦有報錯,手機端訪問卻能完美實現(xiàn),從而走了驗證簽名的過程到最后卻并非錯在簽名,當然也不排除你的操作過程簽名一定是沒問題的哦.

代碼實現(xiàn)如下:
/**
* 支付寶支付post提交頁面
*/
public function alipay(){
if (IS_POST){
Vendor('Alipay.aop.AopClient');
Vendor('Alipay.aop.request.AlipayTradeWapPayRequest');
//$out_trade_no = I('post.order_sn');
/*
* $out_trade_no 為自己業(yè)務(wù)邏輯中要支付的訂單號
* 可從POST數(shù)據(jù)中提取,具體安全起見可自行加密操作 此處僅舉例測試數(shù)據(jù)
* $order_amount 為要進行支付的金額 注意要用小數(shù)轉(zhuǎn)換
* 例如:3.50,10.00
* $aliConfig 獲取支付寶配置數(shù)據(jù)
*/
$out_trade_no = '2017M'.time();
$body = '歡迎購買商品,愿您購物愉快';
$subject = '你好';
$order_amount = 9.00;
$aliConfig = C('ALI_CONFIG');
$aop = new \AopClient();
$aop->gatewayUrl = $aliConfig['gatewayUrl'];
$aop->appId = $aliConfig['appId'];
$aop->rsaPrivateKey = $aliConfig['rsaPrivateKey'];
$aop->alipayrsaPublicKey=$aliConfig['alipayrsaPublicKey'];
$aop->apiVersion = '1.0';
$aop->postCharset='UTF-8';
$aop->format='json';
$aop->signType='RSA2';
$request = new \AlipayTradeWapPayRequest ();
$bizContent = "{" .
" \"body\":\"$body.\"," .
" \"subject\":\"$subject\"," .
" \"out_trade_no\":\"$out_trade_no\"," .
" \"timeout_express\":\"90m\"," .
" \"total_amount\":$order_amount," .
" \"product_code\":\"QUICK_WAP_WAY\"" .
" }";
$request->setBizContent($bizContent);
$request->setNotifyUrl($aliConfig['notifyUrl']);
$request->setReturnUrl($aliConfig['returnUrl']);
$result = $aop->pageExecute ( $request);
echo $result;
}else{
echo 'sorry,非法請求失敗';
}
}
6).支付成功后的通知處理
此時,通過獲取所提交過來的post數(shù)據(jù),進行訂單號的剝離,從而進行下一步的業(yè)務(wù)邏輯處理即可.
[注意]:
- 接口文檔中有點明,支付通知功能最后需要輸出‘success'
- 此處的通知路徑要與配置中確定的 ‘notifyUrl'完全一致
/**
* 支付寶支付通知功能
*/
public function notify_ali(){
$out_trade_no = I('post.out_trade_no');
$this->toUpdatePayInfo($out_trade_no,'ali');
echo 'success';
}
三.電腦網(wǎng)站支付接口實現(xiàn)
對比來看,其實 PC 端的代碼設(shè)計與手機端大同小異,在此點明一下使用情景,可進行參考。
1).支付接口實現(xiàn)

提示:
-
測試發(fā)現(xiàn),接口中定義“subject”時,對于文字的數(shù)目有要求,不能超過四個字,至于字母似乎沒有特別限制,開發(fā)過程中原想顯示全部的商品名稱卻無法實現(xiàn),還請注意。
-
提供的代碼暫時未進行界面的設(shè)計,可參考 手機端接口思想,接收并處理訂單信息后再喚醒支付寶,當前的代碼可以在公共文件配置正確的情況下,直接公網(wǎng)訪問接口鏈接即可展示效果。
-
支付成功后的通知處理,請參考手機端實現(xiàn)方式.
2).實現(xiàn)效果截圖



3).代碼實現(xiàn)如下:
/**
* 電腦端喚醒 支付寶掃碼支付接口
*/
public function aliPayPage(){
$out_trade_no = '2017PC'.time();
$order_amount = '12.88';
$proName = "真米黑米 XXXXXX";
Vendor('Alipay.aop.AopClient');
Vendor('Alipay.aop.request.AlipayTradePagePayRequest');
//構(gòu)造參數(shù)
$aop = new \AopClient();
$aliConfig = C('ALI_CONFIG');
$aop->gatewayUrl = $aliConfig['gatewayUrl'];
$aop->appId = $aliConfig['appId'];
$aop->rsaPrivateKey = $aliConfig['rsaPrivateKey'];
$aop->apiVersion = '1.0';
$aop->signType = 'RSA2';
$aop->postCharset= 'utf-8';
$aop->format='json';
$request = new \AlipayTradePagePayRequest ();
$request->setReturnUrl($aliConfig['returnPcUrl']);
$request->setNotifyUrl($aliConfig['notifyUrl']);
$request->setBizContent(
"{" .
" \"product_code\":\"FAST_INSTANT_TRADE_PAY\"," .
" \"subject\":\"$proName\"," .
" \"out_trade_no\":\"$out_trade_no\"," .
" \"total_amount\":$order_amount," .
" \"body\":\"Iphone6 16G\"" .
" }");
//請求
$result = $aop->pageExecute ($request);
//輸出
echo $result;
}
附錄:
源代碼下載>>>
更多關(guān)于thinkPHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《ThinkPHP入門教程》、《thinkPHP模板操作技巧總結(jié)》、《ThinkPHP常用方法總結(jié)》、《codeigniter入門教程》、《CI(CodeIgniter)框架進階教程》、《Zend FrameWork框架入門教程》及《PHP模板技術(shù)總結(jié)》。
希望本文所述對大家基于ThinkPHP框架的PHP程序設(shè)計有所幫助。
您可能感興趣的文章:- ThinkPHP實現(xiàn)微信支付(jsapi支付)流程教程詳解
- Thinkphp整合微信支付功能
- thinkphp整合微信支付代碼分享
- Thinkphp和onethink實現(xiàn)微信支付插件
- ThinkPHP框架整合微信支付之Native 掃碼支付模式一圖文詳解
- ThinkPHP框架整合微信支付之JSAPI模式圖文詳解
- ThinkPHP框架整合微信支付之Native 掃碼支付模式二圖文詳解
- thinkPHP框架對接支付寶即時到賬接口回調(diào)操作示例
- Thinkphp微信公眾號支付接口
- ThinkPHP實現(xiàn)支付寶接口功能實例
- ThinkPHP框架整合微信支付之刷卡模式圖文詳解