laravel+php+支付功能,Laravel 使用微信支付进行支付开发实例

微信支付在现在是非常的流行了特别是在手机中我们只需要简单的操作即可完成支付了,下面我们来看一篇关于Laravel 使用微信支付进行支付开发实例,具体的操作细节如下所示。

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

1、安装依赖包

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

composer require overtrue/laravel-wechat 2.1.*

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

Overtrue\LaravelWechat\ServiceProvider::class

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

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

2、配置微信公众号设置

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

php artisan vendor:publish

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

return [

'use_alias' => env('WECHAT_USE_ALIAS', false),

'app_id' => env('WECHAT_APPID', 'Your AppId'), // 必填

'secret' => env('WECHAT_SECRET', 'Your Secret'), // 必填

'token' => env('WECHAT_TOKEN', 'Your Token'), // 必填

'encoding_key' => env('WECHAT_ENCODING_KEY', 'Your Encoding AES Key') // 只有加密模式需要

];

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

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

3、使用示例

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

PHP

use Overtrue\Wechat\Payment;

use Overtrue\Wechat\Payment\Order;

use Overtrue\Wechat\Payment\Business;

use Overtrue\Wechat\Payment\UnifiedOrder;

/**

* 第 1 步:定义商户

*/

$business = new Business(

APP_ID,

APP_KEY,

MCH_ID,

MCH_KEY

);

/**

* 第 2 步:定义订单

*/

$order = new Order();

$order->body = 'test body';

$order->out_trade_no = md5(uniqid().microtime());

$order->total_fee = '1'; // 单位为 “分”, 字符串类型

$order->openid = OPEN_ID;

$order->notify_url = 'http://xxx.com/wechat/payment/notify';

/**

* 第 3 步:统一下单

*/

$unifiedOrder = new UnifiedOrder($business, $order);

/**

* 第 4 步:生成支付配置文件

*/

$payment = new Payment($unifiedOrder);

Javascript

var WXPayment = function() {

if( typeof WeixinJSBridge === 'undefined' ) {

alert('请在微信在打开页面!');

return false;

}

WeixinJSBridge.invoke(

'getBrandWCPayRequest', <?php echo $payment->getConfig(); ?>, function(res) {

switch(res.err_msg) {

case 'get_brand_wcpay_request:cancel':

alert('用户取消支付!');

break;

case 'get_brand_wcpay_request:fail':

alert('支付失败!(' res.err_desc ')');

break;

case 'get_brand_wcpay_request:ok':

alert('支付成功!');

break;

default:

alert(JSON.stringify(res));

break;

}

}

);

}

HTML

支付 ¥<?php echo ($order->total_fee / 100); ?> 元

支付通知

use Overtrue\Wechat\Payment\Notify;

$notify = new Notify(

APP_ID,

APP_KEY,

MCH_ID,

MCH_KEY

);

$transaction = $notify->verify();

if (!$transaction) {

$notify->reply('FAIL', 'verify transaction error');

}

// var_dump($transaction);

echo $notify->reply();

4、在Lumen中使用

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

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

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

WECHAT_USE_ALIAS=false

WECHAT_APPID=xxx

WECHAT_SECRET=xxx

WECHAT_TOKEN=xxx

WECHAT_ENCODING_KEY=xxx

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

$app->configure('wechat');

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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
首先,你需要在 Midway.js 项目中安装 `tenpay` 包。可以通过以下命令进行安装: ``` npm install tenpay --save ``` 接下来,我们需要创建一个 `TenpayService` 类,用于封装微信支付相关的代码。在该类中,我们需要实现以下方法: - `getPaymentParams`:用于获取微信支付的参数; - `verifyPaymentResult`:用于验证微信支付结果的有效性。 以下是一个示例 `TenpayService` 类的代码: ```typescript import { provide } from '@midwayjs/decorator'; import { IWebMiddleware, IMidwayKoaContext } from '@midwayjs/koa'; import { Payment } from 'tenpay'; @provide() export class TenpayService { private readonly payment: Payment; constructor() { this.payment = new Payment({ appid: 'YOUR_APPID', mchid: 'YOUR_MCHID', partnerKey: 'YOUR_PARTNERKEY', notify_url: 'YOUR_NOTIFY_URL', spbill_create_ip: 'YOUR_SPBILL_CREATE_IP', // 是否沙箱环境 sandbox: true }); } async getPaymentParams(order: any): Promise<any> { const params = { out_trade_no: order.outTradeNo, body: order.body, total_fee: order.totalFee, openid: order.openid, trade_type: 'JSAPI', }; const result = await this.payment.getPayParams(params); return result; } async verifyPaymentResult(params: any): Promise<boolean> { const result = await this.payment.verifyNotify(params); return result; } } ``` 其中,`getPaymentParams` 方法会根据订单信息,调用 `tenpay` 包的 `getPayParams` 方法获取微信支付的参数。`verifyPaymentResult` 方法会根据微信支付结果的参数,调用 `tenpay` 包的 `verifyNotify` 方法验证结果的有效性。 接下来,我们可以在控制器中使用 `TenpayService` 类,来实现微信支付功能。以下是一个示例控制器的代码: ```typescript import { provide, inject } from '@midwayjs/decorator'; import { Context } from 'egg'; import { TenpayService } from './tenpay.service'; @provide() export class TenpayController { @inject() ctx: Context; @inject() tenpayService: TenpayService; async createOrder() { // 创建订单 const order = { outTradeNo: 'YOUR_OUT_TRADE_NO', body: 'YOUR_BODY', totalFee: 100, openid: 'YOUR_OPENID', }; // 获取微信支付参数 const params = await this.tenpayService.getPaymentParams(order); // 返回给前端的数据 const data = { appId: params.appId, timeStamp: params.timeStamp, nonceStr: params.nonceStr, package: params.package, signType: params.signType, paySign: params.paySign, }; return data; } async notify() { const params = this.ctx.request.body; const result = await this.tenpayService.verifyPaymentResult(params); // 处理支付结果 if (result) { // 支付成功 // TODO: 处理订单状态等业务逻辑 this.ctx.body = 'success'; } else { // 支付失败 this.ctx.body = 'fail'; } } } ``` 以上代码中的 `createOrder` 方法用于创建订单,并调用 `TenpayService` 类的 `getPaymentParams` 方法获取微信支付参数。`notify` 方法用于处理微信支付结果的通知,调用 `TenpayService` 类的 `verifyPaymentResult` 方法验证结果的有效性,并根据结果处理订单状态等业务逻辑。 最后,在 `config/config.default.ts` 中配置路由: ```typescript import { EggAppConfig, PowerPartial } from 'egg'; import { IWebMiddleware } from '@midwayjs/koa'; export default () => { const config: PowerPartial<EggAppConfig> = {}; config.middleware = ['errorHandler']; config.routes = [ { method: 'POST', path: '/api/tenpay/createOrder', action: 'tenpay.createOrder', }, { method: 'POST', path: '/api/tenpay/notify', action: 'tenpay.notify', }, ]; return config; }; ``` 以上就是使用 Midway.js + TypeScript 实现微信 JSAPI 支付的教程。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值