微信支付 SDK for Golang

objcoding · · 3906 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

一个为Go语言量身定做、超级好用的微信支付SDK。

GitHub地址:wxpay

微信支付开发文档API

微信支付开发者文档中给出的API进行了封装。

wxpay提供了对应的方法:

| 方法名 | 说明 |

| ---------------- | ----------- |

| MicroPay | 刷卡支付 |

| UnifiedOrder | 统一下单 |

| OrderQuery | 查询订单 |

| Reverse | 撤销订单 |

| CloseOrder | 关闭订单 |

| Refund | 申请退款 |

| RefundQuery | 查询退款 |

| DownloadBill | 下载对账单 |

| Report | 交易保障 |

| ShortUrl | 转换短链接 |

| AuthCodeToOpenid | 授权码查询openid |

  • 参数为Params类型,返回类型也是ParamsParams 是一个 map[string]string 类型的结构体。

  • 方法内部会将参数会转换成含有appidmch_idnonce_strsign\_typesign的XML;

  • 默认使用MD5进行签名;

  • 通过HTTPS请求得到返回数据后会对其做必要的处理(例如验证签名,签名错误则抛出异常)。

  • 对于downloadBill,无论是否成功都返回Map,且都含有return_codereturn_msg。若成功,其中return_codeSUCCESS,另外data对应对账单数据。

安装


go get github.com/objcoding/wxpay

示例


// 新建微信支付客户端

client := wxpay.NewClient(wxpay.NewAccount{

AppID: "appid",

MchID: "mchid",

ApiKey: "apiKey",

}, false) // sandbox环境请传true

// 统一下单

params := make(wxpay.Params)

params.SetString("body", "test").

SetString("out_trade_no", "436577857").

SetInt64("total_fee", 1).

SetString("spbill_create_ip", "127.0.0.1").

SetString("notify_url", "http://notify.objcoding.com/notify").

SetString("trade_type", "APP")

p, _ := client.UnifiedOrder(params)

// 订单查询

params := make(wxpay.Params)

params.SetString("out_trade_no", "3568785")

p, _ := client.OrderQuery(params)

// 退款

params := make(wxpay.Params)

params.SetString("out_trade_no", "3568785").

SetString("out_refund_no", "19374568").

SetInt64("total_fee", 1).

SetInt64("refund_fee", 1)

p, _ := client.Refund(params)

// 退款查询

params := make(wxpay.Params)

params.SetString("out_refund_no", "3568785")

p, _ := client.RefundQuery(params)


// 创建支付账户

account := wxpay.NewAccount("appid", "mchid", "apiKey")

// 设置证书

account.SetCertData("证书地址")

// 新建微信支付客户端

client := wxpay.NewClient(account, false) // sandbox环境请传true

// 设置http请求超时时间

client.SetHttpConnectTimeoutMs(2000)

// 设置http读取信息流超时时间

client.SetHttpReadTimeoutMs(1000)

// 更改签名类型

client.SetSignType(HMACSHA256)

// 设置支付账户

client.setAccount(account)


// 签名

signStr := client.Sign(params)

// 校验签名

b := client.ValidSign(params)


// 支付或退款返回成功信息

return wxpay.Notifies{}.OK()

// 支付或退款返回失败信息

return wxpay.Notifies{}.NotOK("支付失败或退款失败了")

License

MIT license


有疑问加站长微信联系(非本文作者)

本文来自:简书

感谢作者:objcoding

查看原文:微信支付 SDK for Golang

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

3906 次点击  
加入收藏 微博
3 回复  |  直到 2019-07-24 11:15:31
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传