news 2026/3/25 19:30:06

汇付支付jspay go代码流程

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
汇付支付jspay go代码流程

下面给出一份「汇付 JSPay(公众号支付)」在 Go 语言里的最小可跑通流程,全部字段与汇付 2025 版接口保持一致,可直接拷贝到项目里改配置即用。步骤分 4 步:
1. 初始化商户配置
2. 拼装统一下单参数并签名
3. 请求汇付网关拿到 pay_info
4. 把 pay_info 原样返给前端,前端用 WeixinJSBridge 调起支付
5. 监听异步通知并验签
代码中只依赖官方库 github.com/huifubspay/bspay-sdk-go(2025-05 发布的 v2 版),不再自己算 RSA。
package main

import (
"encoding/json"
"fmt"
"log"
"net/http"
"time"

"github.com/huifubspay/bspay-sdk-go/config"
"github.com/huifubspay/bspay-sdk-go/request"
"github.com/huifubspay/bspay-sdk-go/utils"
)

/* ========== 步骤 0:一次性配置 ========== */
var (
hfCfg = &config.MerchantConfig{
ProductID: "你的 product_id", // 汇付后台产品编号
SysID: "你的 sys_id", // 系统编号
HuifuID: "你的 huifu_id", // 商户号
PrivateKey: `-----BEGIN PRIVATE KEY-----
... 你的私钥
-----END PRIVATE KEY-----`,
HuifuPublicKey: `-----BEGIN PUBLIC KEY-----
... 汇付公钥
-----END PUBLIC KEY-----`,
NotifyURL: "https://你的域名/huifu/notify", // 支付结果通知地址
}
)

/* ========== 步骤 1:下单并获取 pay_info ========== */
type OrderReq struct {
OrderID string `json:"order_id"` // 业务订单号
OpenID string `json:"open_id"` // 用户在公众号下的 openid
Amount string `json:"amount"` // 元,保留 2 位小数
Desc string `json:"desc"` // 商品描述
ClientIP string `json:"client_ip"` // 用户 IP
}

func CreateJSPayOrder(req OrderReq) (payInfo string, err error) {
body := make(map[string]interface{})
body["req_date"] = time.Now().Format("20060102")
body["req_seq_id"] = req.OrderID
body["huifu_id"] = hfCfg.HuifuID
body["trade_type"] = "T_JSAPI" // 公众号支付
body["sub_appid"] = "你的公众号 appid"
body["sub_openid"] = req.OpenID
body["trans_amt"] = req.Amount
body["goods_desc"] = req.Desc
body["notify_url"] = hfCfg.NotifyURL
body["client_ip"] = req.ClientIP

// SDK 自动加签、发送、解包
resp, err := request.DoRequest(body, "/v2/aggregate/trans/jsapi", hfCfg)
if err != nil {
return "", err
}
// 取前端要的 pay_info
payInfo, _ = resp["pay_info"].(string)
return payInfo, nil
}

/* ========== 步骤 2:前端调起支付 ========== */
// 下面是一个最简 handler,把 pay_info 原样返给前端
func orderHandler(w http.ResponseWriter, r *http.Request) {
var req OrderReq
if err := json.NewDecoder(r.Body).Decode(&req); err != nil {
http.Error(w, err.Error(), http.StatusBadRequest)
return
}
payInfo, err := CreateJSPayOrder(req)
if err != nil {
http.Error(w, err.Error(), http.StatusInternalServerError)
return
}
// 前端拿到后直接 eval 即可调起支付
json.NewEncoder(w).Encode(map[string]string{"pay_info": payInfo})
}

/* ========== 步骤 3:异步通知 ========== */
func notifyHandler(w http.ResponseWriter, r *http.Request) {
// 汇付通知是 JSON + RSA 签名放在 header Huifu-Sign
sign := r.Header.Get("Huifu-Sign")
bodyBytes, _ := io.ReadAll(r.Body)
if !utils.VerifySign(string(bodyBytes), sign, hfCfg.HuifuPublicKey) {
log.Println("验签失败")
w.WriteHeader(http.StatusBadRequest)
return
}
// 验签通过 -> 解密 -> 拿到交易状态
var notice map[string]interface{}
json.Unmarshal(bodyBytes, &notice)
if notice["trans_stat"] == "S" {
log.Println("支付成功,订单号=", notice["req_seq_id"])
}
// 必须返回 200
w.Write([]byte("success"))
}

/* ========== 步骤 4:main ========== */
func main() {
// 初始化全局配置
config.Init(hfCfg)

http.HandleFunc("/api/huifu/order", orderHandler)
http.HandleFunc("/huifu/notify", notifyHandler)
log.Println("listen :8080")
log.Fatal(http.ListenAndServe(":8080", nil))
}

前端拿到 /api/huifu/order 返回的 pay_info 后,直接注入即可:
const res = await fetch('/api/huifu/order',{method:'POST',body:JSON.stringify({order_id:'123',open_id:'oXXX',amount:'0.01',desc:'测试',client_ip:'127.0.0.1'})})
const {pay_info} = await res.json()
eval(pay_info) // 汇付返回的就是一段 WeixinJSBridge.invoke(...) 代码

至此,Go 后端职责完成:下单、签名、验签、通知全部走官方 SDK,无需自己拼 XML 或算 RSA。若后续要支持「小程序支付」,只需把 trade_type 换成 T_MINIAPP 并把 sub_appid 换成小程序 appid 即可。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/17 23:32:27

一篇搞定 dotnet ef:EF Core 常用命令与实战指南

基础知识项目说明EF Core.NET 的 ORM 框架,支持 Code First、Database First。dotnet ef一个 CLI 工具,用于管理 EF Core 迁移、数据库操作。安装方式通常安装在项目中(推荐):dotnet add package Microsoft.EntityFram…

作者头像 李华
网站建设 2026/3/16 2:15:26

GPU选型避坑指南,部署Open-AutoGLM必须掌握的4类显卡对比

第一章:Open-AutoGLM部署硬件要求部署 Open-AutoGLM 模型对硬件资源配置有较高要求,尤其在推理与微调场景下需确保系统具备足够的计算能力、内存带宽和存储空间。为保障模型稳定运行,建议根据实际应用场景选择合适的硬件配置。最低硬件配置 C…

作者头像 李华
网站建设 2026/3/16 2:15:33

Dubbo vs Spring Cloud:微服务架构的终极对决——剖析与选择指南

文章目录Dubbo 和 Spring Cloud 的区别?1. 背景介绍1.1 Dubbo 是什么?1.2 Spring Cloud 是什么?2. 核心区别2.1 设计理念2.2 核心功能对比2.2.1 服务注册与发现2.2.2 配置管理2.2.3 服务调用2.2.4 熔断机制2.2.5 负载均衡2.2.6 总线通信3. 总…

作者头像 李华
网站建设 2026/3/22 8:20:34

Open-AutoGLM部署避坑大全(90%新手都会犯的3个致命错误)

第一章:Open-AutoGLM部署前的核心准备在正式部署 Open-AutoGLM 之前,必须完成一系列关键的准备工作,以确保系统能够稳定运行并充分发挥其自动化代码生成与推理能力。这些准备涵盖环境依赖、模型资源获取以及配置文件的初始化。环境依赖安装 O…

作者头像 李华
网站建设 2026/3/15 8:48:34

基于最优控制的汽车 1/4 主动悬架系统仿真之旅

基于最优控制的汽车1/4主动悬架系统仿真 Matlab&simulink仿真 分别用lqr和Hinf进行控制 现成模型和代码在汽车工程领域,悬架系统对于车辆的行驶舒适性和操纵稳定性起着至关重要的作用。今天咱就来唠唠基于最优控制的汽车 1/4 主动悬架系统仿真,而且是…

作者头像 李华