上一节我们讨论了在Laravel中如何使用支付宝进行支付,这一节我们讲另一种常见的支付方式:银联支付。通过上一节的学习想必大家已经了解了OmniPay这个牛逼的GitHub项目,也对如何使用OmniPay for Laravel 5 & Lumen这个Laravel包有了大致的了解。没错,我们接下来要讲的银联支付还是使用这个Laravel包,并集成OmniPay提供的银联支付(UnionPay)接口——UmniPay UnionPay。
废话不多说,下面直接切入正题。由于我们在上一节已经安装了ignited/laravel-omnipay这个包,这里我们只需要安装银联支付包即可:
- composer require lokielse/omnipay-unionpay dev-master
到银联支付开发者中心注册账户并提交商户资料进行审核,等待审核通过后获取相关证书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
):
配置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'
- ]
- ]
OmniPay UnionPay提供了以下支付网关接口:
本例中我们使用Union_Express网关。
- //银联支付处理
- 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
。
在浏览中访问http://laravel.app:8000/unionpay/pay
,页面会跳转到银联支付页面:
我们将测试银行卡号填写到输入框并点击下一步:
将测试卡号对应身份证号码填入输入框,然后点击“免费获取”,最后直接将手机验证码111111填写到验证码输入框,然后点击“确认付款”,页面就会跳转到支付成功页面:
点击“返回商户”,则页面跳转到http://laravel.app:8000/unionpay/return
并显示:
- 支付成功!
我们这里简单测试了支付和回调接口,更多接口方法使用请参考Omnipay: UnionPay。