ThinkPHP框架下整合支付寶支付功能圖文教程
本文實例講述了ThinkPHP框架下整合支付寶支付功能。分享給大家供大家參考,具體如下:
背景
- 近期項目需要接入支付寶支付功能,其中開發(fā)使用了ThinkPHP3.2.3框架,通過參考開發(fā)平臺文檔可以知道,網(wǎng)站開發(fā)有兩種場景,一種是手機網(wǎng)站支付,直接喚醒支付寶app進入支付操作;另一種多是 PC 端顯示支付二維碼的形式,然后使用手機的支付寶app掃描。
- 此處主要介紹手機網(wǎng)站支付的實現(xiàn),后期補充掃碼支付。
一.接入配置
1).接入步驟
根據(jù)“快速接入”中的流程,兩者大同小異,都是進行:
- 第一步:創(chuàng)建應用并獲取APPID
- 第二步:配置密鑰
- 第三步:搭建和配置開發(fā)環(huán)境
- 第四步:調(diào)用接口
2).配置截圖
3).提示說明
雖然官方文檔已經(jīng)做的很詳細、成熟,不過還是有幾點需要著重提醒一下,以免不必要的糾結(jié)。
- 應用創(chuàng)建成功后需要大概一到三天的審核
- 配置密鑰時建議下載其提供的加密工具,可參考RSA密鑰生成方法
- 此處我所下載的是開發(fā)平臺服務端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)建應用后生成 //由開發(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).服務端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è)務邏輯中要支付的訂單號 * 可從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è)務邏輯處理即可.
[注意]:
- 接口文檔中有點明,支付通知功能最后需要輸出‘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è)計有所幫助。
相關(guān)文章
php側(cè)拉菜單 漂亮,可以向右或者向左展開,支持FF,IE
其中menu UL UL的left或者right控制向右或者向左顯示子菜單2009-10-10Laravel框架實現(xiàn)多數(shù)據(jù)庫連接操作詳解
這篇文章主要介紹了Laravel框架實現(xiàn)多數(shù)據(jù)庫連接操作,結(jié)合實例形式詳細分析了Laravel框架連接2個數(shù)據(jù)庫的具體操作步驟與相關(guān)實現(xiàn)技巧,需要的朋友可以參考下2019-07-07編寫PHP程序檢查字符串中的中文字符個數(shù)的實例分享
這篇文章主要介紹了編寫PHP程序檢查字符串中的中文字符個數(shù)的實例分享,文中利用了PHP中mb_strlen函數(shù)的實現(xiàn)原理,需要的朋友可以參考下2016-03-03php web環(huán)境和命令行環(huán)境下查找php.ini的位置
這篇文章主要介紹了php web環(huán)境和命令行環(huán)境下如何查找php.ini的位置,需要的朋友可以參考下2019-07-07使用php的HTTP請求的庫Requests實現(xiàn)美女圖片墻
這篇文章主要介紹了使用php的HTTP請求的庫Requests實現(xiàn)美女圖片墻的方法,十分簡單實用,需要的朋友可以參考下2015-02-02