Laravel 支付解决方案之如何使用银联支付进行支付
上一节我们讨论了在Laravel中如何使用支付宝进行支付,这一节我们讲另一种常见的支付方式:银联支付。通过上一节的学习想必大家已经了解了OmniPay这个牛逼的GitHub项目,也对如何使用OmniPay for Laravel 5 & Lumen这个Laravel包有了大致的了解。没错,我们接下来要讲的银联支付还是使用这个Laravel包,并集成OmniPay提供的银联支付(UnionPay)接口——UmniPay UnionPay。
1、安装银联支付依赖包
废话不多说,下面直接切入正题。由于我们在上一节已经安装了ignited/laravel-omnipay这个包,这里我们只需要安装银联支付包即可:
composer require lokielse/omnipay-unionpay dev-master
2、获取银联支付配置信息
到银联支付开发者中心注册账户并提交商户资料进行审核,等待审核通过后获取相关证书ID等信息用于填写银联支付配置选项。
如果你是测试的话银联支付提供了相应的测试接口和配置数据:
以及测试银行卡信息:
卡号 | 卡性质 | 机构名称 | 手机号码 | 密码 | CVN2 | 有效期 | 证件号 | 姓名 |
---|---|---|---|---|---|---|---|---|
6216261000000000018 | 借记卡 | 平安银行 | 13552535506 | 123456 | 341126197709218366 | 全渠道 | ||
6221558812340000 | 贷记卡 | 平安银行 | 13552535506 | 123456 | 123 | 1711 | 341126197709218366 | 互联网 |
短信验证码 | 111111 |
然后我们去https://open.unionpay.com/ajweb/help/file/techFile下载PHP版本的实例代码,比如我们这里测试的是网关支付,那就下载网关支付对应的实例代码,解压下载的压缩文件,然后将下面这个三个文件拷出来放到Laravel项目指定目录(比如storage/app/unionpay/certs
):
3、配置文件
配置config/laravel-omnipay.php
(如果没有该配置文件参考上一节相应操作),添加银联支付配置:
'unionpay' => [ 'driver' => 'UnionPay_Express', 'options' => [ 'merId' => '777290058120462', 'certPath' => '/path/to/storage/app/unionpay/certs/PM_700000000000001_acp.pfx', 'certPassword' =>'000000', 'certDir'=>'/path/to/certs', 'returnUrl' => 'Your ReturnUrl Here', 'notifyUrl' => 'Your NotifyUrl Here' ] ]
4、基本使用
OmniPay UnionPay提供了以下支付网关接口:
- Union_Express 银联全产品网关(PC,APP,WAP支付)
- Union_LegacyMobile 银联老网关(APP)
- Union_LegacyQuickPay 银联老网关(PC)
定义路由
//银联支付处理 Route::get('unionpay/pay','UnionpayController@pay'); //支付后回调页面 Route::post('unionpay/return','UnionpayController@result');
支付
新建控制器UnionPayController
,定义pay
方法:
public function pay(){ $gateway = Omnipay::gateway('unionpay'); $order = [ 'orderId' => date('YmdHis'), 'txnTime' => date('YmdHis'), 'orderDesc' => 'My test order title', //订单名称 'txnAmt' => '100', //订单价格 ]; $response = $gateway->purchase($order)->send(); $response->redirect(); }
回调
定义result
方法:
public function result(){ $gateway = Omnipay::gateway('unionpay'); $response = $gateway->completePurchase(['request_params'=>$_REQUEST])->send(); if ($response->isPaid()) { exit('支付成功!'); }else{ exit('支付失败!'); } }
此外,由于该回调请求来自第三方API,无法通过CSRF验证,所以需要在CSRF验证中排除该URL,否则会抛出TokenMismatchException异常,具体排除方法可参考CSRF攻击原理及其防护这篇教程,这里我们要排除的URL是unionpay/return
。
5、银联支付测试
在浏览中访问http://laravel.app:8000/unionpay/pay
,页面会跳转到银联支付页面:
我们将测试银行卡号填写到输入框并点击下一步:
将测试卡号对应身份证号码填入输入框,然后点击“免费获取”,最后直接将手机验证码111111填写到验证码输入框,然后点击“确认付款”,页面就会跳转到支付成功页面:
点击“返回商户”,则页面跳转到http://laravel.app:8000/unionpay/return
并显示:
支付成功!
我们这里简单测试了支付和回调接口,更多接口方法使用请参考Omnipay: UnionPay。
14 Comments
一直报,Class 'Illuminate\Support\Facades\Omnipay' not found,use也引入了,还是不行
老哥你好,我在点击返回商户时报了个错:Can not find certId in folder storage/app/unionpay/certs。请问是什么原因呢?我dd($gateway)时有看到request体内的attribute中有success以及挺多参数的,但就是不明白为什么会报这个错,然后中断了
已经解决了!少了个证书。加入到certs目录即可。最新版的需要手动添加该证书:verify_sign_acp.cer