当前位置: 首页 > news >正文

汇付支付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 即可。

http://www.jsqmd.com/news/129413/

相关文章:

  • 视觉重塑精度:基于电鱼智能 RK3588 的手术室多屏异显与 8K 视频分发方案
  • 项目绩效域管理 论文框架
  • 香港视频网站服务器租用全攻略
  • 香港视频网站服务器租用全攻略
  • 继续教育课程智能推荐平台——采用anything-llm驱动
  • 2025年年终Jira替代软件推荐:主流平台横向测评与5款高可靠性榜单 - 十大品牌推荐
  • 2025年年终类似Jira的工具推荐:基于效能数据与多品牌实测的TOP5排名揭晓 - 十大品牌推荐
  • Open-AutoGLM插件究竟有多强?(AI自动化操作黑科技曝光)
  • Pollard-Rho 质因数分解板子
  • 2025最新新能源客车怎么选?宇通客车以全系产品链领跑绿色出行新时代 - 深度智识库
  • 筑牢工业安全防线:基于电鱼智能 RK3568 的双千兆网口防火墙架构方案
  • 3.7V升压5V芯片深度剖析:PW5100/PW5300A/PW6276,选型无忧
  • 汇付支付notify返回哪些信息
  • 2025 年 12 月高压清洗服务权威推荐榜:专业上门施工与深度保养,涵盖管道、化粪池及市政道路的全场景高效洁净解决方案 - 品牌企业推荐师(官方)
  • Open-AutoGLM架构设计精讲,揭秘支撑万级并发的底层逻辑
  • SMBus协议短报文与长报文对比解析
  • 2025年口碑好的封阳台系统门窗厂家推荐及选购参考榜 - 品牌宣传支持者
  • 告别“电老虎”!基于电鱼智能 RK3568 的低功耗工业边缘算力架构演进方案
  • 47、编程知识综合解析与实践
  • UVM中针对DUT的寄存器模型适配详解
  • GuideNav:面向盲人旅行者的纯视觉机器人导航助手的用户知情开发 - MKT
  • 48、Windows Forms 控件详解
  • Open-AutoGLM上线GitHub:5大核心功能带你抢先掌握AI编程新范式
  • 医疗 AI 边缘化:电鱼智能 RK3576 离线部署 DeepSeek 医疗大模型实践指南
  • 还在花钱买API?用Open-AutoGLM自建免费高性能模型服务,省下90%成本
  • 2025年质量好的成都集装箱移动房屋/集装箱TOP实力厂家推荐榜 - 品牌宣传支持者
  • GPU选型避坑指南,部署Open-AutoGLM必须掌握的4类显卡对比
  • LangFlow是否将成为下一代AI IDE?行业专家观点
  • jlink驱动下载快速理解:5分钟掌握基本流程
  • Activiti 连接瀚高数据库