支付宝接口的使用

首先打开composer的库https://packagist.org/packages/latrell/alipay

1.在laravel项目的根目录下面执行composer require latrell/alipay dev-master

支付宝接口的使用_第1张图片
Paste_Image.png

支付宝接口的使用_第2张图片
Paste_Image.png

有时候我发现上面那条命令执行总是下载不下来,那么我也可以这样composer require latrell/alipay dev-master

使用

要使用支付宝SDK服务提供者,你必须自己注册服务提供者到Laravel/Lumen服务提供者列表中。 基本上有两种方法可以做到这一点。

2.vim config/app.php 配置文件中,key为 providers 的数组,在数组中添加服务提者。

  'providers' => [ 'Latrell\Alipay\AlipayServiceProvider', ]

如果是lumen
在bootstrap/app.php里注册服务。

$app->register(Latrell\Alipay\AlipayServiceProvider::class);
然后参考https://packagist.org/packages/latrell/alipay

3.运行 php artisan vendor:publish命令,发布配置文件到你的项目中。

说明

配置文件 config/latrell-alipay.php为公共配置信息文件,
config/latrell-alipay-web.php为Web版支付宝SDK配置,
config/latrell-alipay-mobile.php为手机端支付宝SDK配置。

4.vim config/latrell-alipay.php

支付宝接口的使用_第3张图片
Paste_Image.png

5.网页vim config/latrell-alipay-web.php

支付宝接口的使用_第4张图片
Paste_Image.png

6.手机:config/latrell-alipay-mobile.php

支付宝接口的使用_第5张图片
Paste_Image.png

如果是手机 config文件夹下要建一个 key文件夹 放公钥私钥文件

支付宝接口的使用_第6张图片
Paste_Image.png

例子

支付申请

网页

// 创建支付单。
$alipay = app('alipay.web');
$alipay->setOutTradeNo('9486292811467365887'); //订单号
$alipay->setTotalFee('0.01');  //支付金额
$alipay->setSubject('商品名称');
$alipay->setBody('商品描述');

$alipay->setQrPayMode('4'); //该设置为可选,添加该参数设置,只显示一个二维码支付。建议不要加这条参数

// 跳转到支付页面。
return redirect()->to($alipay->getPayLink());
支付宝接口的使用_第7张图片
Paste_Image.png

$alipay->setQrPayMode('4')的参数

参数是1


支付宝接口的使用_第8张图片
Paste_Image.png

参数是2

支付宝接口的使用_第9张图片
Paste_Image.png

参数3

支付宝接口的使用_第10张图片
Paste_Image.png

参数是4


支付宝接口的使用_第11张图片
Paste_Image.png

手机端

// 创建支付单。
$alipay = app('alipay.mobile');
$alipay->setOutTradeNo('order_id');
$alipay->setTotalFee('order_price');
$alipay->setSubject('goods_name');
$alipay->setBody('goods_description');

// 返回签名后的支付参数给支付宝移动端的SDK。
return $alipay->getPayPara();

结果通知

网页

/**
 * 异步通知
 */
public function webNotify()
{
    // 验证请求。
    if (! app('alipay.web')->verify()) {
        Log::notice('Alipay notify post data verification fail.', [
            'data' => Request::instance()->getContent()
        ]);
        return 'fail';
    }

    // 判断通知类型。
    switch (Input::get('trade_status')) {
        case 'TRADE_SUCCESS':
        case 'TRADE_FINISHED':
            // TODO: 支付成功,取得订单号进行其它相关操作。
            Log::debug('Alipay notify post data verification success.', [
                'out_trade_no' => Input::get('out_trade_no'),
                'trade_no' => Input::get('trade_no')
            ]);
            break;
    }

    return 'success';
}

/**
 * 同步通知
 */
public function webReturn()
{
    // 验证请求。
    if (! app('alipay.web')->verify()) {
        Log::notice('Alipay return query data verification fail.', [
            'data' => Request::getQueryString()
        ]);
        return view('alipay.fail');
    }

    // 判断通知类型。
    switch (Input::get('trade_status')) {
        case 'TRADE_SUCCESS':
        case 'TRADE_FINISHED':
            // TODO: 支付成功,取得订单号进行其它相关操作。
            Log::debug('Alipay notify get data verification success.', [
                'out_trade_no' => Input::get('out_trade_no'),
                'trade_no' => Input::get('trade_no')
            ]);
            break;
    }

    return view('alipay.success');
}

手机端

/**
 * 支付宝异步通知
 */
public function alipayNotify()
{
    // 验证请求。
    if (! app('alipay.mobile')->verify()) {
        Log::notice('支付失败--Alipay notify post data verification fail.', [
            'data' => Request::instance()->getContent()
        ]);
        return 'fail';
    }

    // 判断通知类型。
    switch (Input::get('trade_status')) {
        case 'TRADE_SUCCESS':
        case 'TRADE_FINISHED':
            // TODO: 支付成功,取得订单号进行其它相关操作。
            Log::debug('支付成功--Alipay notify get data verification success.', [
                'out_trade_no' => Input::get('out_trade_no'),
                'trade_no' => Input::get('trade_no')
            ]);
            break;
    }

    return 'success';
}

提示 :使用日志的时候,必须把日志类引入 use Illuminate\Support\Facades\Log;

3、return_url(同步) 与 notify_url(异步) 的区别

买家付款成功后,如果接口中指定有return_url ,买家付完款后会跳到 return_url所在的页面,这个页面可以展示给客户看,这个页面只有付款成功才会跳转.

notify_url:

服务器后台通知,这个页面是程序后台运行的(买家和卖家都看不到),买家付完款后,支付宝会调用notify_url这个页面所在的页面并把相应的参数传递到这个页面,这个页面根据支付宝传递过来的参数修改网站订单的状态,更新完订单后需要在页面上打印出一个success给支付宝,如果反馈给支付宝的不是success,支付宝会继续调用这个页面.
流程:买家付完款(trade_status=WAIT_SELLER_SEND_GOODS)--->支付宝通知notify_url---&
gt;如果反馈给支付宝的是success(表示成功,这个状态下不再反馈,如果不是继续通知,一般第一次发送和第二次发送的时间间隔是3分钟)
剩下的过程,卖家发货,买家确认收货,交易成功都是这个流程

你可能感兴趣的:(支付宝接口的使用)