Laravel 支付解决方案之如何使用微信支付进行支付


Laravel中使用微信支付

前两节我们陆续讲了在Laravel中如何使用支付宝和银联支付进行支付,这一节我们来探讨另一种时下热门的支付方式——微信支付。说来也是,微信那么多用户,微信推出来的支付工具用的人自然不少,尤其是微信红包对微信支付的推广更是起到至关重要的作用。正因如此许多网站和App都添加了对微信支付的支持。

Laravel作为全世界最流行的PHP框架,在国内也是拥有许多拥趸,也就自然不乏对微信支付的支持,当然和支付宝、银联支付一样也是通过第三方的扩展包来实现,不过这一次,不是基于OmniPay,因为OmniPay中貌似并没有对微信支付提供网关接口,但是没关系,轮子总是有人造的(目前已提供对微信支付支持:Omnipay-WeChat),目前GitHub上在Laravel中封装微信SDK的项目不在少数,其中最流行的当属overture开发的laravel-wechat和huanghua581开发的laravel-wechat-sdk。当然overture还开发了独立于框架的Wechat,laravel-wechat正是基于该项目进行开发。

本节我们就使用laravel-wechat包对微信支付做一简单使用示例。

1、安装依赖包

在项目根目录下运行如下命令安装依赖:

  1. composer require overtrue/laravel-wechat 2.1.*

安装完成后在config/app.php中注册服务提供者:

  1. Overtrue\LaravelWechat\ServiceProvider::class

如果你想在代码中通过WeChat门面,可以将其添加到config/app.phpaliases数组中:

  1. 'Wechat' => Overtrue\LaravelWechat\Facade::class

2、配置微信公众号设置

完成上述操作后,运行如下命令发布配置文件到config目录:

  1. php artisan vendor:publish

运行成功后编辑config/wechat.php文件:

  1. <?php
  2. return [
  3. 'use_alias' => env('WECHAT_USE_ALIAS', false),
  4. 'app_id' => env('WECHAT_APPID', 'Your AppId'), // 必填
  5. 'secret' => env('WECHAT_SECRET', 'Your Secret'), // 必填
  6. 'token' => env('WECHAT_TOKEN', 'Your Token'), // 必填
  7. 'encoding_key' => env('WECHAT_ENCODING_KEY', 'Your Encoding AES Key') // 只有加密模式需要
  8. ];

将你的微信公众号的相关信息填写到对应配置,需要注意的是如果要使用微信支付功能,需要经过认证的公众号,且目前微信公众平台测试账号不支持支付接口。

使用微信支付前,需要先到微信公众平台配置好授权目录、测试账号等信息。 微信支付开发文档可参考:https://pay.weixin.qq.com/wiki/doc/api/index.html

3、使用示例

注:Laravel 5 默认启用了 CSRF 中间件,因为微信的消息是 POST 过来,所以会触发 CSRF 检查导致无法正确响应消息,所以可以在CSRF验证中排除指定URL。具体可参考:Laravel中如何从CSRF中排除指定URL。

PHP

  1. <?php
  2.  
  3. use Overtrue\Wechat\Payment;
  4. use Overtrue\Wechat\Payment\Order;
  5. use Overtrue\Wechat\Payment\Business;
  6. use Overtrue\Wechat\Payment\UnifiedOrder;
  7.  
  8. /**
  9. * 第 1 步:定义商户
  10. */
  11. $business = new Business(
  12. APP_ID,
  13. APP_KEY,
  14. MCH_ID,
  15. MCH_KEY
  16. );
  17.  
  18. /**
  19. * 第 2 步:定义订单
  20. */
  21. $order = new Order();
  22. $order->body = 'test body';
  23. $order->out_trade_no = md5(uniqid().microtime());
  24. $order->total_fee = '1'; // 单位为 “分”, 字符串类型
  25. $order->openid = OPEN_ID;
  26. $order->notify_url = 'http://xxx.com/wechat/payment/notify';
  27.  
  28. /**
  29. * 第 3 步:统一下单
  30. */
  31. $unifiedOrder = new UnifiedOrder($business, $order);
  32.  
  33. /**
  34. * 第 4 步:生成支付配置文件
  35. */
  36. $payment = new Payment($unifiedOrder);

Javascript

  1. var WXPayment = function() {
  2. if( typeof WeixinJSBridge === 'undefined' ) {
  3. alert('请在微信在打开页面!');
  4. return false;
  5. }
  6. WeixinJSBridge.invoke(
  7. 'getBrandWCPayRequest', <?php echo $payment->getConfig(); ?>, function(res) {
  8. switch(res.err_msg) {
  9. case 'get_brand_wcpay_request:cancel':
  10. alert('用户取消支付!');
  11. break;
  12. case 'get_brand_wcpay_request:fail':
  13. alert('支付失败!('+res.err_desc+')');
  14. break;
  15. case 'get_brand_wcpay_request:ok':
  16. alert('支付成功!');
  17. break;
  18. default:
  19. alert(JSON.stringify(res));
  20. break;
  21. }
  22. }
  23. );
  24. }

HTML

  1. <button type="button" onclick="WXPayment()">
  2. 支付 ¥<?php echo ($order->total_fee / 100); ?>
  3. </button>

支付通知

  1. <?php
  2.  
  3. use Overtrue\Wechat\Payment\Notify;
  4.  
  5. $notify = new Notify(
  6. APP_ID,
  7. APP_KEY,
  8. MCH_ID,
  9. MCH_KEY
  10. );
  11.  
  12. $transaction = $notify->verify();
  13.  
  14. if (!$transaction) {
  15. $notify->reply('FAIL', 'verify transaction error');
  16. }
  17.  
  18. // var_dump($transaction);
  19.  
  20. echo $notify->reply();

4、在Lumen中使用

此外,laravel-wechat还支持Lumen。使用Composer安装完laravel-wechat后需要在bootstrap/app.php中82行左右添加这一行代码:

  1. $app->register(Overtrue\LaravelWechat\ServiceProvider::class);

同时在ENV中配置以下选项:

  1. WECHAT_USE_ALIAS=false
  2. WECHAT_APPID=xxx
  3. WECHAT_SECRET=xxx
  4. WECHAT_TOKEN=xxx
  5. WECHAT_ENCODING_KEY=xxx

如果你习惯使用 config/wechat.php 来配置的话,请记得在 bootstrap/app.php 中19行以后添加:

  1. $app->configure('wechat');

当然,除此之外,laravel-wechat还提供了更多微信SDK支持,具体请参考:https://github.com/overtrue/wechat/wiki。