推荐开源项目:`node-tenpay` - 轻松集成微信支付到Node.js应用中

推荐开源项目:node-tenpay - 轻松集成微信支付到Node.js应用中

项目简介

`` 是一个基于Node.js编写的微信支付SDK,由开发者befinal贡献并维护。它旨在简化微信支付接口的调用,帮助开发者快速且稳定地在自己的Node.js应用程序中集成微信支付功能。

技术分析

核心特性

  1. 完整的API覆盖node-tenpay 包含了微信支付的所有主要功能,如订单创建、支付、退款、查询等,几乎涵盖了从交易开始到结束的每一个环节。
  2. 易于使用:采用Promise进行异步处理,使得代码更符合现代JavaScript的编程风格,易于理解和集成。
  3. 错误处理:内建的错误处理机制能够捕捉和解析微信支付返回的错误信息,提供更友好的错误提示。
  4. 文档齐全:项目的文档详细解释了每个方法的用途、参数及返回值,方便开发人员查阅和使用。

使用示例

const Tenpay = require('node-tenpay');
const tenpay = new Tenpay({appId: 'your_app_id', mchId: 'your_mch_id', key: 'your_key'});

tenpay.unifiedOrder({
    body: '商品描述',
    out_trade_no: '你的订单号',
    total_fee: 100, // 单位为分
    spbill_create_ip: '客户端IP',
    notify_url: '你的通知URL',
    trade_type: 'JSAPI',
    openId: '用户的OpenID'
}).then(res => {
    console.log('预付单创建成功', res);
}).catch(err => {
    console.error('预付单创建失败', err);
});

应用场景

node-tenpay 可广泛应用于需要微信支付功能的各种Node.js项目,包括但不限于:

  • 电子商务网站:轻松实现在线购物的支付流程。
  • 移动应用后端:与前端App配合,提供便捷的支付服务。
  • 服务类平台:为用户提供充值、购买服务等支付解决方案。
  • 订阅制应用:用于处理定期扣费订阅服务。

特点

  1. 跨平台性:基于Node.js,可在任何支持Node.js的平台上运行。
  2. 轻量级:体积小巧,不影响主应用性能。
  3. 高可定制性:可以根据实际需求调整和扩展功能。
  4. 活跃维护:开发者对项目持续更新和维护,确保与微信支付接口同步。

如果你正在寻找一个稳定可靠的Node.js微信支付解决方案,node-tenpay 绝对值得尝试。立即加入社区,发掘更多可能,并为你的应用添加微信支付功能吧!

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 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
发出的红包

打赏作者

温宝沫Morgan

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值