支援 支付 查詢 退款 退款查詢 交易關閉#
https://github.com/echobool/alipay-laravel5
alipay-laravel5 支付寶電腦網站支付
根據支付寶最新版 電腦網站支付接口SDK 整合laravel5
安裝#
首先安裝 Composer. 已安裝請忽略。
在 composer.json 檔案中添加:
“echobool/alipay-laravel5”: “dev-master”
然後執行composer進行安裝:
$ composer update -vvv
或直接:
$ composer require “echobool/alipay-laravel5:dev-master”
在app.php中加上
EchoBool\AlipayLaravel\AlipayServiceProvider::class,
更新配置
php artisan config:cache
釋出配置檔案
$ php artisan vendor:publish –provider=”EchoBool\AlipayLaravel\AlipayServiceProvider”
如果出現 EchoBool\AlipayLaravel\AlipayServiceProvider not found 則運作下面代碼再釋出
$ composer dump-autoload –optimize
支援#
支付支援表單送出和Curl背景送出方式
當配置檔案中 trade_pay_type=>true 時為表單送出 預設CURL送出。
支援交易查詢操作
支援退款操作
支援退款查詢操作
支援交易關閉操作
用法#
先将config/alipay-web.php 中各項配置好
//檔案頭use一下
use EchoBool\AlipayLaravel\Facades\Alipay;
/**
* 支付
* @param Request request∗@returnmixed∗/publicfunctiongoPay(Request request)
{
//商戶訂單号,商戶網站訂單系統中唯一訂單号,必填
outtradeno=date(‘YmdHis′).‘00045623′;//訂單名稱,必填 subject = ‘鎖貿通任務ID448’;
//付款金額,必填
totalamount=0.01;//商品描述,可空 body = ‘macbook pro2’;
$customData = json_encode(['model_name' => 'ewrwe', 'id' => 121]);//自定義參數
$response = Alipay::tradePagePay($subject, $body, $out_trade_no, $total_amount, $customData);
//輸出表單
return $response['redirect_url'];
}
/**
* 退款
* @param Request $request
*/
public function refund(Request $request)
{
//商戶訂單号
$out_trade_no = $request->get('trade_no');
$refund_amount = 0.01;
$refund_reason = '任務取消退款';
$out_request_no = '201';
$response = Alipay::tradeRefund($out_trade_no, $refund_amount, $refund_reason, $out_request_no);
dd($response);
}
/**
* 退款查詢
* @param Request $request
*/
public function refundQuery(Request $request)
{
//商戶訂單号
$out_trade_no = $request->get('trade_no');
$out_request_no = $request->get('out_request_no');
$response = Alipay::refundQuery($out_trade_no,$out_request_no);
dd($response);
}
/**
* 交易是否成功查詢
* @param Request $request
*/
public function tradePayQuery(Request $request)
{
//商戶訂單号
$out_trade_no = $request->get('trade_no');
$response = Alipay::tradePayQuery($out_trade_no);
dd($response);
}
/**
* 交易關閉
* @param Request $request
*/
public function tradeClose(Request $request)
{
//商戶訂單号
$out_trade_no = $request->get('trade_no');
$response = Alipay::Close($out_trade_no);
dd($response);
}
/**
* 異步通知
* @param Request $request
*/
public function notify(Request $request)
{
$result = Alipay::notify($_POST);
/* 實際驗證過程建議商戶添加以下校驗。
1、商戶需要驗證該通知資料中的out_trade_no是否為商戶系統中建立的訂單号,
2、判斷total_amount是否确實為該訂單的實際金額(即商戶訂單建立時的金額),
3、校驗通知中的seller_id(或者seller_email) 是否為out_trade_no這筆單據的對應的操作方(有的時候,一個商戶可能有多個seller_id/seller_email)
4、驗證app_id是否為該商戶本身。
*/
if ($result) {//驗證成功
/
//請在這裡加上商戶的業務邏輯程式代
//——請根據您的業務邏輯來編寫程式(以下代碼僅作參考)——
//擷取支付寶的通知傳回參數,可參考技術文檔中伺服器異步通知參數清單
//商戶訂單号
$out_trade_no = $_POST['out_trade_no'];
//支付寶交易号
$trade_no = $_POST['trade_no'];
//交易狀态
$trade_status = $_POST['trade_status'];
if ($_POST['trade_status'] == 'TRADE_FINISHED') {
//判斷該筆訂單是否在商戶網站中已經做過處理
//如果沒有做過處理,根據訂單号(out_trade_no)在商戶網站的訂單系統中查到該筆訂單的詳細,并執行商戶的業務程式
//請務必判斷請求時的total_amount與通知時擷取的total_fee為一緻的
//如果有做過處理,不執行商戶的業務程式
//注意:
//退款日期超過可退款期限後(如三個月可退款),支付寶系統發送該交易狀态通知
} else if ($_POST['trade_status'] == 'TRADE_SUCCESS') {
//判斷該筆訂單是否在商戶網站中已經做過處理
//如果沒有做過處理,根據訂單号(out_trade_no)在商戶網站的訂單系統中查到該筆訂單的詳細,并執行商戶的業務程式
//請務必判斷請求時的total_amount與通知時擷取的total_fee為一緻的
//如果有做過處理,不執行商戶的業務程式
//注意:
//付款完成後,支付寶系統發送該交易狀态通知
}
//——請根據您的業務邏輯來編寫程式(以上代碼僅作參考)——
echo "success"; //請不要修改或删除
} else {
//驗證失敗
echo "fail";
}
}
/**
* 同步通知 即支付成功後跳轉到return_url 上時進行驗證 如果支付方式是CURL方式将不會跳轉 請注意
* @param Request $request
*/
public function returnUrl(Request $request)
{
$result = Alipay::notify($_GET);
/* 實際驗證過程建議商戶添加以下校驗。
1、商戶需要驗證該通知資料中的out_trade_no是否為商戶系統中建立的訂單号,
2、判斷total_amount是否确實為該訂單的實際金額(即商戶訂單建立時的金額),
3、校驗通知中的seller_id(或者seller_email) 是否為out_trade_no這筆單據的對應的操作方(有的時候,一個商戶可能有多個seller_id/seller_email)
4、驗證app_id是否為該商戶本身。
*/
if ($result) {//驗證成功
/
//請在這裡加上商戶的業務邏輯程式代碼
//——請根據您的業務邏輯來編寫程式(以下代碼僅作參考)——
//擷取支付寶的通知傳回參數,可參考技術文檔中頁面跳轉同步通知參數清單
//商戶訂單号
$out_trade_no = htmlspecialchars($_GET['out_trade_no']);
//支付寶交易号
$trade_no = htmlspecialchars($_GET['trade_no']);
echo "驗證成功<br />支付寶交易号:" . $trade_no;
//——請根據您的業務邏輯來編寫程式(以上代碼僅作參考)——
/
} else {
//驗證失敗
echo "驗證失敗";
}
}