支付寶 電腦網站支付方式 最新的 SDK 整理的包 有需要朋友拿走

echobool發表於2017-06-29

支援 支付 查詢 退款 退款查詢 交易關閉

https://github.com/echobool/alipay-laravel...

根據支付寶最新版 電腦網站支付介面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
     * @return mixed
     */
    public function goPay(Request $request)
    {
        //商戶訂單號,商戶網站訂單系統中唯一訂單號,必填
        $out_trade_no = date('YmdHis') . '00045623';
        //訂單名稱,必填
        $subject = '鎖貿通任務ID448';
        //付款金額,必填
        $total_amount = 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 "驗證失敗";
            }
        }
本作品採用《CC 協議》,轉載必須註明作者和本文連結

相關文章