news 2026/6/9 22:32:20

汇付支付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/6/6 19:05:35

SMBus协议短报文与长报文对比解析

SMBus短报文与长报文:从寄存器读写到批量数据传输的工程实践在嵌入式系统开发中,我们经常需要让主控芯片(如MCU、EC或BMC)与各类低速外设通信。比如读取温度传感器的实时值、配置电源管理IC的工作模式、获取电池剩余电量等。这些任…

作者头像 李华
网站建设 2026/6/3 2:38:14

Open-AutoGLM浏览器插件实战指南:5大核心功能助你提升90%工作效率

第一章:Open-AutoGLM浏览器插件概述Open-AutoGLM 是一款基于现代浏览器扩展架构开发的智能自动化工具,专为提升用户在网页环境中的自然语言交互效率而设计。该插件融合了大型语言模型(LLM)的能力与前端自动化技术,能够…

作者头像 李华
网站建设 2026/6/9 19:57:05

基于 Snowflake Cortex AI 的逆向工程代理,让遗留SQL逻辑一目了然

🧠 逆向工程代理 - 基于 Snowflake Cortex AI 构建 在当今数据驱动的世界中,组织正以前所未有的速度进行现代化转型,但理解遗留 SQL 逻辑仍然是一个巨大的障碍。隐藏在 Snowflake 或旧系统中的存储过程、函数和视图通常缺乏文档,…

作者头像 李华
网站建设 2026/6/9 18:36:26

单点登录集成:anything-llm对接LDAP/Active Directory教程

单点登录集成:anything-LLM对接LDAP/Active Directory教程 在企业AI应用落地的过程中,一个看似不起眼却极其关键的环节往往被忽视——用户登录。想象一下:新员工入职第一天,除了要激活邮箱、领取电脑、加入通讯群组,还…

作者头像 李华
网站建设 2026/6/9 22:08:25

上海Java失业快两个月了,明天出发去南京看看

这是小红书上一位Java程序员失业后重新找工作的真实情况 Java程序员如今深陷技术迭代放缓与行业需求收缩的双重困境,职业发展空间正被新兴技术浪潮持续挤压。面对当前Java程序员可能面临的“发展瓶颈”或行业挑战,更积极的应对策略可以围绕技术升级、方…

作者头像 李华