支付宝 电脑网站支付方式 最新的 SDK 整理的包

支持 支付 查询 退款 退款查询 交易关闭#

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 "验证失败";
        }
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值