当前位置: 首页 > 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.rkmt.cn/news/141956.html

相关文章:

  • 2025年污水药剂、洗砂药剂、絮凝剂、PAM厂家权威推荐:蓝淼环保引领水处理药剂行业,五大品牌实力对决 - 深度智识库
  • 香港视频网站服务器租用全攻略
  • 2025年年终Jira替代软件推荐:主流平台横向测评与5款高可靠性榜单 - 十大品牌推荐
  • 筑牢工业安全防线:基于电鱼智能 RK3568 的双千兆网口防火墙架构方案
  • GuideNav:面向盲人旅行者的纯视觉机器人导航助手的用户知情开发 - MKT
  • 48、Windows Forms 控件详解
  • 医疗 AI 边缘化:电鱼智能 RK3576 离线部署 DeepSeek 医疗大模型实践指南
  • 还在花钱买API?用Open-AutoGLM自建免费高性能模型服务,省下90%成本
  • 2025年质量好的成都集装箱移动房屋/集装箱TOP实力厂家推荐榜 - 品牌宣传支持者
  • GPU选型避坑指南,部署Open-AutoGLM必须掌握的4类显卡对比
  • jlink驱动下载快速理解:5分钟掌握基本流程
  • 【Open-AutoGLM开源揭秘】:如何利用GitHub最新AI框架实现自动化代码生成
  • 数据错位危机:当2TB数据库遭遇对齐错误
  • 电路仿真circuits网页版中比较器电路的设计核心要点
  • anything-llm能否用于舆情分析?文本摘要与情感识别能力测试
  • 专利查重预审:用Anything-LLM初步判断创新点相似度
  • 还在公有云跑AutoGLM?本地化部署成本直降70%的实操方案来了
  • 你的結構體 alignment 正在謀殺 CPU cache:一場看不見的性能屠殺
  • Open-AutoGLM 2.0怎么下载并快速接入本地模型?实战经验一次性公开
  • 利用anything-llm构建法律文书查询系统的可行性分析
  • 企业级大模型落地部署技术步骤 2025,非常详细收藏我这一篇就好了
  • 2025年12月广东铁艺栏杆,广东锻打切割铁艺栏杆,广东欧式铁艺栏杆厂家推荐:行业测评与选择指南 - 品牌鉴赏师
  • 手把手教你基于2025机顶盒刷机包开发定制系统
  • 【Open-AutoGLM浏览器插件深度解析】:揭秘AI自动化操作新利器及高效使用技巧
  • 《2025浙江智能营销服务商深度评测:聚焦AI搜索与短视频的精准增长实战》 - 呼呼拉呼
  • 如何限制用户上传文件大小?anything-llm配置项调整说明
  • ResNet文献阅读笔记
  • 未来家居可能的新变化:从“智能设备堆叠”到“自适应生活系统”
  • 全网口碑好的盒马鲜生礼品卡回收平台推荐 - 京顺回收
  • 2025年12月广州广告不锈钢字,天河广告,车陂广告宣传栏厂家推荐:行业测评与选择指南 - 品牌鉴赏师