問題詳情:
本文實例講述了PHP實現(xiàn)的支付寶的支付功能。
分享給大家供大家參考,具體如下:
在給app做支付寶支付接口的時候收集內(nèi)容整理如下:
接口:
import('alipay.AopClient', EXTEND_PATH); import('alipay.request.AlipayTradeAppPayRequest', EXTEND_PATH); $aop = new AopClient(); $aop->gatewayUrl = "https://openapi.alipay.com/gateway.do"; $aop->appId = Config::get('alipay.app_id'); $aop->rsaPrivateKey = Config::get('alipay.rsa_private_key'); $aop->format = "json"; $aop->charset = "UTF-8"; $aop->signType = "RSA2"; $aop->alipayrsaPublicKey = Config::get('alipay.alipay_rsa_public_key'); //Config::get('alipay.rsa_public_key'); // $request = new AlipayTradeAppPayRequest(); $bizcontent = json_encode([ 'body' => '紅包支付', 'subject' => '用戶紅包支付', 'out_trade_no' => $orderSn, 'timeout_express' => '30m', 'total_amount' => $amount, 'product_code' => 'QUICK_MSECURITY_PAY' ]); $request->setNotifyUrl("https://" . $_SERVER['HTTP_HOST'] . "/api/callback/alipay"); $request->setBizContent($bizcontent);//這里和普通的接口調(diào)用不同,使用的是sdkExecute $response = $aop->sdkExecute($request); $return['aliresponse'] = $response;//htmlspecialchars($response);//htmlspecialchars是為了輸出到頁面時防止被瀏覽器將關(guān)鍵參數(shù)html轉(zhuǎn)義,實際打印到日志以及http傳輸不會有這個問題 $this->returnSuccess($return);
回調(diào)處理:
public function alipay() { import('alipay.AopClient', EXTEND_PATH); $aop = new AopClient(); $aop->alipayrsaPublicKey = Config::get('alipay.alipay_rsa_public_key');// file_get_contents($_SERVER['DOCUMENT_ROOT']."/key/alipay/alipay_public_key.txt"); $flag = $aop->rsaCheckV1($_POST, NULL, "RSA2"); if ($flag){ //驗簽通過后核實如下參數(shù)trade_status、out_trade_no、total_amount、seller_id if (isset($_POST['trade_status']) && ($_POST['trade_status'] == 'TRADE_SUCCESS' || $_POST['trade_status'] == 'TRADE_FINISHED') ) { // 業(yè)務(wù)處理 } else { $msg = var_export($_POST, true); $fileName = mt_rand(10,1000) .'00alisuccessAnother.log' ; file_put_contents($fileName, $msg); } echo "success"; } else { $msg = var_export($_POST, true); $fileName = mt_rand(10,1000) .'00alicheckSignFail.log'; file_put_contents($fileName, $msg); } }
更多學(xué)習(xí)推薦:支付寶即時到賬在線支付實戰(zhàn)項目開發(fā)視頻教程
附:支付寶支付和微信支付異步回調(diào)一直調(diào)用
最近在開發(fā)支付寶支付,前期的工作都已經(jīng)做好了,但是在異步回調(diào)取值的時候,異步回調(diào)一直在調(diào)用,弄得我數(shù)據(jù)一直重復(fù)的存入數(shù)據(jù)庫,仔細思考下,腦海中立馬浮現(xiàn)的一個解決方法就是,在異步回調(diào),里面再寫一個接口,每次回調(diào)取到數(shù)據(jù)后,查詢數(shù)據(jù)庫,看看有沒有數(shù)據(jù),如果有就不重復(fù)存入,但是仔細一想,不對啊,這是治標不治本啊,不行,既然有問題,肯定有根源,有正確的解決方法。所以,找起根據(jù),那就是查看文檔:
1. 支付寶文檔,下面這是支付寶異步回調(diào)的文檔:
服務(wù)器異步通知頁面特性
必須保證服務(wù)器異步通知頁面(notify_url)上無任何字符,如空格、HTML標簽、開發(fā)系統(tǒng)自帶拋出的異常提示信息等;
支付寶是用POST方式發(fā)送通知信息,因此該頁面中獲取參數(shù)的方式,如:request.Form(“out_trade_no”)、$_POST[‘out_trade_no'];
支付寶主動發(fā)起通知,該方式才會被啟用;
只有在支付寶的交易管理中存在該筆交易,且發(fā)生了交易狀態(tài)的改變,支付寶才會通過該方式發(fā)起服務(wù)器通知(即時到賬交易狀態(tài)為“等待買家付款”的狀態(tài)默認
是不會發(fā)送通知的);
服務(wù)器間的交互,不像頁面跳轉(zhuǎn)同步通知可以在頁面上顯示出來,這種交互方式是不可見的;
第一次交易狀態(tài)改變(即時到賬中此時交易狀態(tài)是交易完成)時,不僅會返回同步處理結(jié)果,而且服務(wù)器異步通知頁面也會收到支付寶發(fā)來的處理結(jié)果通知;
程序執(zhí)行完后必須打印輸出“success”(不包含引號)。如果商戶反饋給支付寶的字符不是success這7個字符,支付寶服務(wù)器會不斷重發(fā)通知,直到超過24小時22分鐘。
一般情況下,25小時以內(nèi)完成8次通知(通知的間隔頻率一般是:4m,10m,10m,1h,2h,6h,15h);
程序執(zhí)行完成后,該頁面不能執(zhí)行頁面跳轉(zhuǎn)。如果執(zhí)行頁面跳轉(zhuǎn),支付寶會收不到success字符,會被支付寶服務(wù)器判定為該頁面程序運行出現(xiàn)異常,而重發(fā)處理結(jié)果通知;
cookies、session等在此頁面會失效,即無法獲取這些數(shù)據(jù);
該方式的調(diào)試與運行必須在服務(wù)器上,即互聯(lián)網(wǎng)上能訪問;
該方式的作用主要防止訂單丟失,即頁面跳轉(zhuǎn)同步通知沒有處理訂單更新,它則去處理;
當商戶收到服務(wù)器異步通知并打印出success時,服務(wù)器異步通知參數(shù)notify_id才會失效。也就是說在支付寶發(fā)送同一條異步通知時
(包含商戶并未成功打印出success導(dǎo)致支付寶重發(fā)數(shù)次通知),服務(wù)器異步通知參數(shù)notify_id是不變的。
看到?jīng)],程序必須要打印出來success
后,支付寶才會停止噴血,自己再回頭看程序的時候,發(fā)現(xiàn)自己的確沒有返回success
,所以在程序結(jié)束后,返回一個success
即可。由于我使用的php,在程序結(jié)束后。使用下面一句話即可。
eg: echo "success";
2. 微信文檔
支付完成后,微信會把相關(guān)支付結(jié)果和用戶信息發(fā)送給商戶,商戶需要接收處理,并返回應(yīng)答。
對后臺通知交互時,如果微信收到商戶的應(yīng)答不是成功或超時,微信認為通知失敗,微信會通過一定的策略定期重新發(fā)起通知,盡可能提高通知的成功率,但微信不保證通知
最終能成功。 (通知頻率為15/15/30/180/1800/1800/1800/1800/3600,單位:秒)
注意:同樣的通知可能會多次發(fā)送給商戶系統(tǒng)。商戶系統(tǒng)必須能夠正確處理重復(fù)的通知。
推薦的做法是,當收到通知進行處理時,首先檢查對應(yīng)業(yè)務(wù)數(shù)據(jù)的狀態(tài),判斷該通知是否已經(jīng)處理過,如果沒有處理過再進行處理,如果處理過直接返回結(jié)果成功。
在對業(yè)務(wù)數(shù)據(jù)進行狀態(tài)檢查和處理之前,要采用數(shù)據(jù)鎖進行并發(fā)控制,以避免函數(shù)重入造成的數(shù)據(jù)混亂。
特別提醒:商戶系統(tǒng)對于支付結(jié)果通知的內(nèi)容一定要做簽名驗證,并校驗返回的訂單金額是否與商戶側(cè)的訂單金額一致,防止數(shù)據(jù)泄漏導(dǎo)致出現(xiàn)“假通知”,造成資金損失。
技術(shù)人員可登進微信商戶后臺掃描加入接口報警群。
看到?jīng)],在此文檔也是,在微信的異步通知后,也需要給微信服務(wù)器,返回一個信息,只不過,微信的所有數(shù)據(jù)格式都是xml的。所以我們在返回一個數(shù)據(jù)給微信即可。
echo "<xml><return_code><![CDATA[SUCCESS]]></return_code><return_msg><![CDATA[OK]]></return_msg></xml>";
在進行返回的時候,格式?jīng)]問題,可能在輸出的時候,存在問題。使用下面方式即可:
echo exit('<xml><return_code><![CDATA[SUCCESS]]></return_code><return_msg><![CDATA[OK]]></return_msg></xml>');
就是這么簡單,完美結(jié)局!
相關(guān)學(xué)習(xí)推薦:php視頻教程
聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com