用Go语言实现微信支付SDK

微信公众号「后端进阶」,专一后端技术分享:Java、Golang、WEB框架、分布式中间件、服务治理等等。
老司机倾囊相授,带你一路进阶,来不及解释了快上车!git

wxpay for golang

注:本人照着微信支付官方 SDK Java 版,用 Go 语言实现的一个微信支付 SDK,与 Java 版功能一致,具有轻量易上手,且功能齐全的特色,理论上性能也会比 Java 版的更快。github

GitHub地址:github.com/objcoding/w…golang

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 licenseapi

公众号「后端进阶」,专一后端技术分享!
相关文章
相关标签/搜索