Skip to content

微信支付官方SDK for Golang.(Go最好用的微信支付SDK)

License

Notifications You must be signed in to change notification settings

NodejsMAS/wxpay

Repository files navigation

wxpay for golang

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

微信支付开发文档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

About

微信支付官方SDK for Golang.(Go最好用的微信支付SDK)

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Go99.5%
  • Shell0.5%