您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“php服務端集成支付寶APP支付的示例分析”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“php服務端集成支付寶APP支付的示例分析”這篇文章吧。
一、創建應用及配置
首先,需要到螞蟻金服開發平臺(open.alipay.com)注冊應用,并獲取應用ID,并配置應用,這里在配置時主要是簽約,生成應用的RSA2公私鑰,同時獲取到支付寶提供的支付公鑰等,這部分官網后臺都有提示,比較簡單
二、下載對應SDK
這里我是在PHP后臺集成服務,因此下載的是PHP SDK,地址:https://docs.open.alipay.com/54/103419/
三、準備一個可以訪問的真實域名
四、案例
當以上三部完成之后,此時就可以進入配置我們自己的業務代碼了
4.1、組織APP支付時的支付訂單信息
<?php require_once (__DIR__.'/alipay-sdk-PHP-20171023143822/AopSdk.php'); class Alipay { /** * 應用ID */ const APPID = '你的應用ID'; /** *請填寫開發者私鑰去頭去尾去回車,一行字符串 */ const RSA_PRIVATE_KEY = '應用對應開發者私鑰'; /** *請填寫支付寶公鑰,一行字符串 */ const ALIPAY_RSA_PUBLIC_KEY = '支付寶提供的公鑰'; /** * 支付寶服務器主動通知商戶服務器里指定的頁面 * @var string */ private $callback = "http://www.test.com/notify/alipay_notify.php"; /** *生成APP支付訂單信息 * @param string $orderId 商品訂單ID * @param string $subject 支付商品的標題 * @param string $body 支付商品描述 * @param float $pre_price 商品總支付金額 * @param int $expire 支付交易時間 * @return bool|string 返回支付寶簽名后訂單信息,否則返回false */ public function unifiedorder($orderId, $subject,$body,$pre_price,$expire){ try{ $aop = new \AopClient(); $aop->gatewayUrl = "https://openapi.alipay.com/gateway.do"; $aop->appId = self::APPID; $aop->rsaPrivateKey = self::RSA_PRIVATE_KEY; $aop->format = "json"; $aop->charset = "UTF-8"; $aop->signType = "RSA2"; $aop->alipayrsaPublicKey = self::ALIPAY_RSA_PUBLIC_KEY; //實例化具體API對應的request類,類名稱和接口名稱對應,當前調用接口名稱:alipay.trade.app.pay $request = new \AlipayTradeAppPayRequest(); //SDK已經封裝掉了公共參數,這里只需要傳入業務參數 $bizcontent = "{\"body\":\"{$body}\"," //支付商品描述 . "\"subject\":\"{$subject}\"," //支付商品的標題 . "\"out_trade_no\":\"{$orderId}\"," //商戶網站唯一訂單號 . "\"timeout_express\":\"{$expire}m\"," //該筆訂單允許的最晚付款時間,逾期將關閉交易 . "\"total_amount\":\"{$pre_price}\"," //訂單總金額,單位為元,精確到小數點后兩位,取值范圍[0.01,100000000] . "\"product_code\":\"QUICK_MSECURITY_PAY\"" . "}"; $request->setNotifyUrl($this->callback); $request->setBizContent($bizcontent); //這里和普通的接口調用不同,使用的是sdkExecute $response = $aop->sdkExecute($request); //htmlspecialchars是為了輸出到頁面時防止被瀏覽器將關鍵參數html轉義,實際打印到日志以及http傳輸不會有這個問題 return htmlspecialchars($response);//就是orderString 可以直接給客戶端請求,無需再做處理。 }catch (\Exception $e){ return false; } } }
4.2、支付寶支付成功之后異步回調處理
<?php /** * alipay_notify.php. * User: lvfk * Date: 2017/10/26 0026 * Time: 13:48 * Desc: 支付寶支付成功異步通知 */ include_once (__DIR__.'/../alipay-sdk-PHP-20171023143822/AopSdk.php'); //驗證簽名 $aop = new \AopClient(); $aop->alipayrsaPublicKey = \Comm\Pay\Alipay::ALIPAY_RSA_PUBLIC_KEY; $flag = $aop->rsaCheckV1($_POST, NULL, "RSA2"); //驗簽 if($flag){ //處理業務,并從$_POST中提取需要的參數內容 if($_POST['trade_status'] == 'TRADE_SUCCESS' || $_POST['trade_status'] == 'TRADE_FINISHED'){//處理交易完成或者支付成功的通知 //獲取訂單號 $orderId = $_POST['out_trade_no']; //交易號 $trade_no = $_POST['trade_no']; //訂單支付時間 $gmt_payment = $_POST['gmt_payment']; //轉換為時間戳 $gtime = strtotime($gmt_payment); //此處編寫回調處理邏輯 //處理成功一定要返回 success 這7個字符組成的字符串, //die('success');//響應success表示業務處理成功,告知支付寶無需在異步通知 } }
五、遇到的問題
5.1、一直報錯40001=>isv.invalid-signature
為了搞清楚原因,先后多次重新生成應用的RSA2公私密鑰,發現都沒有作用。最后結合網上資料,才發現,原來是支付寶回調地址notifyUrl不能有 '?' 以及 ?后面加參數
5.2、支付寶異步通知成功了,但是$_POST為空
這個也花費了一點時間查找,開始做的時候就是遵照支付寶的建議使用HTTS方式請求。但這樣應用后臺一直通知沒有參數內容。最后才想起來由于我們的應用使用了HTTS雙向認證,這個原因導致支付寶的服務器回調的參數為空。最后,把回調地址改為了HTTP方式,驗證通過
通過遇到的問題,首先查看支付寶的文檔描述以及支付寶提供的錯誤碼解釋,實在不行就百度或者谷歌,再加上自己不斷測試驗證,最終一定可以解決問題
至此,支付寶APP支付這塊功能完成,其他的APP退款、對賬單等等功能就沒繼續做,不過按照支付寶官網文檔以及支付寶提供的SDK,集成到自己應用也只是時間問題。
以上是“php服務端集成支付寶APP支付的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。