首頁 > 後端開發 > php教程 > php服務端整合支付寶APP支付

php服務端整合支付寶APP支付

不言
發布: 2023-03-30 13:28:02
原創
1969 人瀏覽過

以下為大家分享一個php 服務端整合支付寶APP支付實例,具有很好的參考價值,希望對大家有幫助。

支付寶支付分為了很多種場景,這裡只講述支付寶APP支付功能集成,期間遇到了特別大的坑,因此我簡單描述下集成過程,並概述遇到的問題及解決方案

由於公司業務簡單,只支援支付寶支付,而無需關心退款,查詢等等額外功能,因此該篇內容僅講述支付寶支付接口時服務端如何準備APP拉取支付訂單的信息,大概流程如下

一、建立應用程式及設定

#首先,需要到螞蟻金服開發平台(open.alipay.com)註冊應用,並取得應用程式ID,並設定應用程式,這裡在設定時主要是簽約,產生應用程式的RSA2公私鑰,同時取得支付寶提供的支付公鑰等,這部分官網後台都有提示,比較簡單

二、下載對應SDK

這裡我是在PHP後台整合服務,因此下載的是PHP SDK,位址:https://docs.open. alipay.com/54/103419/

三、準備一個可以訪問的真實網域

##4、案例

當以上三部完成之後,此時就可以進入配置我們自己的業務代碼了

4.1、組織APP支付時的支付訂單訊息

<?php

require_once (__DIR__.&#39;/alipay-sdk-PHP-20171023143822/AopSdk.php&#39;);

class Alipay
{
 /**
 * 应用ID
 */
 const APPID = &#39;你的应用ID&#39;;
 /**
 *请填写开发者私钥去头去尾去回车,一行字符串
 */
 const RSA_PRIVATE_KEY = &#39;应用对应开发者私钥&#39;;
 /**
 *请填写支付宝公钥,一行字符串
 */
 const ALIPAY_RSA_PUBLIC_KEY = &#39;支付宝提供的公钥&#39;;
 /**
 * 支付宝服务器主动通知商户服务器里指定的页面
 * @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__.&#39;/../alipay-sdk-PHP-20171023143822/AopSdk.php&#39;);

//验证签名
$aop = new \AopClient();
$aop->alipayrsaPublicKey = \Comm\Pay\Alipay::ALIPAY_RSA_PUBLIC_KEY;
$flag = $aop->rsaCheckV1($_POST, NULL, "RSA2");

//验签
if($flag){
 //处理业务,并从$_POST中提取需要的参数内容
 if($_POST[&#39;trade_status&#39;] == &#39;TRADE_SUCCESS&#39;
 || $_POST[&#39;trade_status&#39;] == &#39;TRADE_FINISHED&#39;){//处理交易完成或者支付成功的通知
 //获取订单号
 $orderId = $_POST[&#39;out_trade_no&#39;];
 //交易号
 $trade_no = $_POST[&#39;trade_no&#39;];
 //订单支付时间
 $gmt_payment = $_POST[&#39;gmt_payment&#39;];
 //转换为时间戳
 $gtime = strtotime($gmt_payment);

 //此处编写回调处理逻辑

		//处理成功一定要返回 success 这7个字符组成的字符串,
		//die(&#39;success&#39;);//响应success表示业务处理成功,告知支付宝无需在异步通知
 
 }
}
登入後複製

、遇到的問題



#5.1、一直報錯40001=>isv.invalid-signature

為了搞清楚原因,先後多次重新產生應用的RSA2公私密鑰,發現都沒有作用。最後結合網路資料,才發現,

原來是支付寶回呼地址notifyUrl不能有'?' 以及?後面加參數

#########5.2、支付寶非同步通知成功了,但是$_POST為空#########這個也花了一點時間查找,開始做的時候就是遵照支付寶的建議使用HTTS方式請求。但這樣應用程式後台一直通知沒有參數內容。最後才想起來由於我們的應用程式使用了HTTS雙向認證,這個原因導致支付寶的伺服器回呼的參數為空。最後,把回調位址改為了HTTP方式,驗證透過######透過遇到的問題,先查看支付寶的文檔描述以及支付寶提供的錯誤碼解釋,實在不行就百度或Google,再加上自己不斷測試驗證,最終一定可以解決問題######至此,支付寶APP支付這塊功能完成,其他的APP退款、對賬單等等功能就沒繼續做,不過按照支付寶官網文檔以及支付寶提供的SDK ,整合到自己應用也只是時間問題。 ######以上就是這篇文章的全部內容了,感謝大家的閱讀,更多內容請關注PHP中文網! #########相關推薦:############thinkPHP交易詳情查詢功能##################

以上是php服務端整合支付寶APP支付的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板