ibrand / pay
ibrand pay component
Installs: 14 901
Dependents: 1
Suggesters: 0
Security: 0
Stars: 13
Watchers: 3
Forks: 2
Open Issues: 1
Requires
- php: >=7.0
- hidehalo/nanoid-php: ^1.1
- yansongda/pay: ^2.5
Requires (Dev)
- mockery/mockery: ~1.0
- orchestra/database: ~3.5
- orchestra/testbench: ~3.5
- phpunit/phpunit: ~6.0
README
Feature
- 实现多渠道支付方式,如:原生支付,pingxx支付,银商支付等。
- 实现多业务统一支付。
- 实现异步通知统一封装。
TODO:
- 实现退款
安装
$ composer require ibrand/pay
$ php artisan vendor:publish
$ php artisan migrate
使用
创建支付请求
发起一次支付请求时需要创建一个新的 charge 对象,获取一个可用的支付凭据用于客户端向第三方渠道发起支付请求。
use iBrand\Component\Pay\Facades\Charge; $charge = Charge::create(['channel' => 'wx_lite' , 'order_no' => $order_no , 'amount' => $order->getNeedPayAmount() , 'client_ip' => \request()->getClientIp() , 'subject' => $order->getSubject() , 'body' => $order->getSubject() , 'extra' => ['openid' => \request('openid')] ]); return $this->success(compact('charge'));
创建 charge 方法定义如下:
public function create(array $data, $type = 'default', $app = 'default');
- $data 参数为支付参数,请见 支付参数一节。
- $type 为业务类型,如果只有一种支付业务,不传即可。如果存在多种业务支付类型,比如商城中存在支付订单,余额充值订单。
- $app 具体的应用名称,比如商城APP和活动APP,可能使用不同的支付配置
支付参数
返回值
发起支付请求后,微信通道会返回 charge 值,如下:
{
"app": "default", // 应用名称
"type": "default", // 业务类型,
"channel": "wx_lite",
"order_no": "O2018111919576278725",
"amount": 4900,
"client_ip": "222.247.67.172",
"subject": "【秋款】2018年儿童秋款T 儿童打底衫秋款 竹节棉阔形儿童T恤 等1件商品",
"body": "【秋款】2018年儿童秋款T 儿童打底衫秋款 竹节棉阔形儿童T恤 等1件商品",
"extra": {
"openid": "ozJEr5NrFkYrNGC5rftcOAO4c3OE"
},
"charge_id": "ch_QAjx7VNJxp2mstAb8kPc0oZR",
"updated_at": "2018-11-20 09:36:45",
"created_at": "2018-11-20 09:36:44",
"id": 4,
"credential": { //客户端支付凭证
"wechat": {
"appId": "wx0ae854a59b88cd63",
"timeStamp": "1542706604",
"nonceStr": "2nbKpiNEY0qHbMaM",
"package": "prepay_id=wx201736451424458ba271c9481469876463",
"signType": "MD5",
"paySign": "8677CEAEDE07E1FCB2E18A460805D98C"
}
},
"out_trade_no": "wx_w5FZYpe0sEyxuCuXF0p3NP_b"
}
异步通知
本包会统一处理支付异步通知,可以通过配置文件来修改异步通知的 url。本报收到异步通知后,会执行 PayNotify::success($charge->type, $charge);
来通知业务方已经完成支付。
业务方在自己的代码中只需要做以下事情即可:
- 实现
iBrand\Component\Pay\Contracts\PayNotifyContract
接口,在success(Charge $charge)
方法中完成业务订单的状态变更。 - 在 ServiceProvider 中绑定
PayNotifyContract
实现。$this->app->bind('ibrand.pay.notify.default',StorePayNotify::class);
其中default
为业务类型值,需要保持和创建 charge 对象时传递的$type
值一致。
同步查询
通常的业务流程中支付完成后,会跳转到支付成功页面,此时需要去主动同步查询订单状态,防止异步通信异常导致订单状态未正确变更的问题。
$charge = Charge::find(request('charge_id'));
$order = PayNotify::success($charge->type, $charge);
配置项
执行 php artisan vendor:publish
后会发布配置文件 config/ibrand/pay.php
return [ /* * 异步通知路由参数 */ 'route' => [ 'prefix' => 'notify', 'middleware' => ['api'], ], /* * 默认的支付渠道类型,default 默认支付驱动类型基于 yansongda/pay 支付宝实现 */ 'driver' => 'default', 'default' => [ 'alipay' => [ /* * APP_NAME,不同的应用会使用不同的支付参数,举例: * 在 iBrand 有商城订单支付,有活动报名支付,两个小程序是不同的 appid 甚至是不同的支付主体,所以需要配置不同的支付参数 * */ 'default' => [ // 支付宝分配的 APPID 'app_id' => env('ALI_PAYMENT_APP_ID', ''), // 支付宝异步通知地址 'notify_url' => '/notify/alipay', // 支付成功后同步通知地址 'return_url' => '', // 阿里公共密钥,验证签名时使用 'ali_public_key' => env('ALI_PAYMENT_PUBLIC_KEY', ''), // 自己的私钥,签名时使用 'private_key' => env('ALI_PAYMENT_PRIVATE_KEY', ''), // optional,默认 warning;日志路径为:sys_get_temp_dir().'/logs/yansongda.pay.log' 'log' => [ 'file' => storage_path('logs/alipay.log'), // 'level' => 'debug' 'type' => 'single', // optional, 可选 daily. 'max_file' => 30, ], // optional,设置此参数,将进入沙箱模式 // 'mode' => 'dev', ], ], 'wechat' => [ 'default' => [ // 公众号 APPID 'app_id' => env('WECHAT_PAYMENT_APP_ID', ''), // 小程序 APPID 'miniapp_id' => env('WECHAT_PAYMENT_MINIAPP_ID', ''), // APP 引用的 appid 'appid' => env('WECHAT_PAYMENT_APPID', ''), // 微信支付分配的微信商户号 'mch_id' => env('WECHAT_PAYMENT_MCH_ID', ''), // 微信支付异步通知地址 'notify_url' => '/notify/wechat', // 微信支付签名秘钥 'key' => env('WECHAT_PAYMENT_KEY', ''), // 客户端证书路径,退款、红包等需要用到。请填写绝对路径,linux 请确保权限问题。pem 格式。 'cert_client' => '', // 客户端秘钥路径,退款、红包等需要用到。请填写绝对路径,linux 请确保权限问题。pem 格式。 'cert_key' => '', // optional,默认 warning;日志路径为:sys_get_temp_dir().'/logs/yansongda.pay.log' 'log' => [ 'file' => storage_path('logs/wechat.log'), // 'level' => 'debug' 'type' => 'single', // optional, 可选 daily. 'max_file' => 30, ], // optional // 'dev' 时为沙箱模式 // 'hk' 时为东南亚节点 // 'mode' => 'dev', ], // ... ], ], ];
Resources
果酱云社区
-
全网真正免费的IT课程平台
-
专注于综合IT技术的在线课程,致力于打造优质、高效的IT在线教育平台
-
课程方向包含Python、Java、前端、大数据、数据分析、人工智能等热门IT课程
-
300+免费课程任你选择