shiqc / alisdk
支付宝SDK在Laravel5封装包。
V1.2.2
2020-04-21 13:54 UTC
Requires
- php: >=5.4.0
- illuminate/config: 5.*
- illuminate/events: 5.*
- illuminate/support: 5.*
This package is auto-updated.
Last update: 2024-09-21 23:45:44 UTC
README
支付宝SDK在Laravel5/Lumen封装包。
该扩展包旨在在Laravel5/Lumen框架下方便使用支付宝。
安装
composer require shiqc/alisdk dev-master
更新依赖包 composer update
或全新安装 composer install
。
使用
要使用支付宝SDK服务提供者,你必须将服务提供者注册到Laravel/Lumen的服务提供者列表中。基本有两种方法可以实现。
Laravel
在 config/app.php
配置文件中找到key为 providers
的数组,向数组中添加服务提供者。
'providers' => [ // ... 'Shiqc\AliSDK\AlipayServiceProvider', ]
运行 php artisan vendor:publish
命令,将配置文件发布到你的项目中。
Lumen
在 bootstrap/app.php
中注册服务。
//Register Service Providers $app->register(Shiqc\AliSDK\AlipayServiceProvider::class);
由于Lumen的 artisan
命令不支持 vendor:publish
,需要手动将 src/config
下的配置文件复制到项目的 config
目录下,并将 config.php
重命名为 shiqc-alisdk.php
,mobile.php
重命名为 shiqc-alisdk-mobile.php
,web.php
重命名为 shiqc-alisdk-web.php
。
说明
配置文件 config/shiqc-alisdk.php
是公共配置信息文件,config/shiqc-alisdk-web.php
是Web版支付宝SDK配置,config/shiqc-alisdk-mobile.php
是手机端支付宝SDK配置。
例子
支付请求
网页端
// 创建支付单。 $alisdk = app('alisdk.web'); $alisdk->setOutTradeNo('order_id'); $alisdk->setTotalFee('order_price'); $alisdk->setSubject('goods_name'); $alisdk->setBody('goods_description'); $alisdk->setQrPayMode('4'); //该设置为可选,添加该参数设置,支持二维码支付。 // 跳转到支付页面。 return redirect()->to($alisdk->getPayLink());
手机端
// 创建支付单。 $alisdk = app('alisdk.mobile'); $alisdk->setOutTradeNo('order_id'); $alisdk->setTotalFee('order_price'); $alisdk->setSubject('goods_name'); $alisdk->setBody('goods_description'); // 返回签名后的支付参数给支付宝移动端的SDK。 return $alisdk->getPayPara();
结果通知
网页端
/** * 异步通知 */ public function webNotify() { // 验证请求。 if (! app('alisdk.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('alisdk.web')->verify()) { Log::notice('Alipay return query data verification fail.', [ 'data' => Request::getQueryString() ]); return view('alisdk.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('alisdk.success'); }
手机端
/** * 支付宝异步通知 */ public function alisdkNotify() { // 验证请求。 if (! app('alisdk.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'; }