All checks were successful
构建并部署到测试环境(无 SSH) / build-and-deploy (push) Successful in 43s
2.7 KiB
2.7 KiB
微信公众号与微信支付集成提案
Why
当前系统的个人客户(C 端用户)无法通过微信公众号登录和使用微信支付功能,导致用户体验不完整。系统已经预留了微信相关的数据模型(wx_open_id, wx_union_id)和支付回调接口,但缺少真实的微信 SDK 集成。为了满足个人客户的核心使用场景(微信扫码登录、钱包充值、购买套餐),需要立即对接微信公众号和微信支付能力。
What Changes
- 新增微信公众号 OAuth 认证:实现用户通过微信授权码获取 OpenID/UnionID 和基本信息(昵称、头像)
- 新增微信支付发起功能:
- H5 支付:支持移动端浏览器外唤起微信支付
- JSAPI 支付:支持微信内网页支付
- 完善微信支付回调处理:在现有回调接口基础上补充签名验证和完整的支付状态同步
- 新增微信配置管理:在配置文件中增加微信公众号和支付的必要参数(AppID、Secret、商户号、证书等)
- 集成 PowerWeChat SDK:使用
github.com/ArtisanCloud/PowerWeChat/v3实现微信 API 调用
Capabilities
New Capabilities
wechat-official-account: 微信公众号能力(OAuth 认证、获取用户信息)wechat-payment: 微信支付能力(H5 支付、JSAPI 支付、支付回调)
Modified Capabilities
无。现有功能不涉及需求级别的变更。
Impact
影响的代码模块:
pkg/wechat/: 微信服务接口实现(替换 Mock 为真实实现)pkg/config/: 新增微信配置项internal/service/personal_customer/: 补充微信 OAuth 登录逻辑internal/service/order/: 新增微信支付发起和回调验证internal/handler/app/: 微信 OAuth 相关 API 端点internal/handler/h5/: 微信支付发起 API 端点internal/handler/callback/: 补充支付回调签名验证
依赖变更:
- 新增依赖:
github.com/ArtisanCloud/PowerWeChat/v3
配置变更:
- 新增环境变量:
JUNHONG_WECHAT_OFFICIAL_ACCOUNT_APP_IDJUNHONG_WECHAT_OFFICIAL_ACCOUNT_APP_SECRETJUNHONG_WECHAT_PAYMENT_MCH_IDJUNHONG_WECHAT_PAYMENT_API_V3_KEY- 等(详见配置设计)
API 变更:
- 修改端点:
POST /api/c/v1/bind-wechat(从"not implemented"变为可用) - 新增端点:
POST /api/h5/orders/:id/wechat-pay/jsapi(JSAPI 支付)POST /api/h5/orders/:id/wechat-pay/h5(H5 支付)
- 增强端点:
POST /api/callback/wechat-pay(补充签名验证)
数据库变更:
- 无。现有表结构已满足需求。
部署影响:
- 需要提供微信商户证书文件(
apiclient_cert.pem、apiclient_key.pem) - 需要配置微信回调域名白名单