/go-union-payment

UnionPayment 是一个整合各种第三方支付网关的工具, 计划支持 Wechat(微信支付)、Alipay(支付宝)、Qpay(QQ钱包)、CMB(招商银行)等。Payment is a Go version of the payment aggregation third-party SDK, which integrates WeChat, Alipay, Qpay, and China Merchant Bank payment.

Primary LanguageGoMIT LicenseMIT

go-union-payment

中文 | English


UnionPayment 是一个整合各种第三方支付网关的工具, 计划支持 Wechat(微信支付)、Alipay(支付宝)、Qpay(QQ钱包)、CMB(招商银行)等等。

之所以存在这个项目,最近公司要做核心服务迁移,目前在经历PHP到GO的重构过程,鉴于之前使用的PHP工具包 [https://github.com/helei112g/payment] 还是比较方便实用,于是借鉴原项目开发者的**,去重新设计一个属于golang领域的聚合支付工具,方便大家使用。

由于项目属于初期启动阶段,更新较快,测试稳定后会进行release发布

欢迎提PR申请一起参与开发

支付网关 支持列表

  • Wechat(微信支付) [开发中]
  • Alipay [计划开发]
  • Qpay [计划开发]
  • China Merchant Bank [计划开发]
  • Palpal [计划开发]

微信支付 API

API 完成状态 官网文档地址
WxApiPayApp 统一下单-APP支付 https://pay.weixin.qq.com/wiki/doc/api/app/app.php?chapter=9_1
WxApiPayWap 统一下单-WAP支付 https://pay.weixin.qq.com/wiki/doc/api/H5.php?chapter=9_20&index=1
WxApiPayPub 统一下单-公众号支付 https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=9_1
WxApiPayLite 统一下单-小程序 https://pay.weixin.qq.com/wiki/doc/api/wxa/wxa_api.php?chapter=9_1
WxApiPayQr 统一下单-QR https://pay.weixin.qq.com/wiki/doc/api/micropay.php?chapter=9_10&index=1
WxApiPayBar 统一下单-NATIVE https://pay.weixin.qq.com/wiki/doc/api/native.php?chapter=9_1
WxApiCloseTrade 🕓 关闭订单 (App\Wap\Lite\Qr\Bar) https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=9_3
WxApiQueryTrade 🕓 查询订单 (App\Wap\Lite\Qr\Bar) https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=9_2
WxApiCancelTrade 🕓 撤销订单(Bar)https://pay.weixin.qq.com/wiki/doc/api/micropay.php?chapter=9_11&index=3
WxApiRefund 🕓 申请退款 https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=9_4
WxApiQueryRefund 🕓 查询退款 https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=9_5
WxApiBillDownload 🕓 下载交易账单 https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=9_6
WxApiFundDownload 🕓 下载资金账单 https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=9_18&index=7
WxNotifyPay 🕓 支付结果通知 https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=9_7&index=8
WxNotifyRefund 🕓 退款结果通知 https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=9_16&index=10
WxApiTransfer 🕓 企业付款 零钱 https://pay.weixin.qq.com/wiki/doc/api/tools/mch_pay.php?chapter=14_2
WxApiQueryTransfer 🕓 查询企业付款 https://pay.weixin.qq.com/wiki/doc/api/tools/mch_pay.php?chapter=14_3
WxApiTransferBank 🕓 企业付款 银行卡 https://pay.weixin.qq.com/wiki/doc/api/tools/mch_pay.php?chapter=24_2
WxApiQueryTransferBank 🕓 查询企业付款 https://pay.weixin.qq.com/wiki/doc/api/tools/mch_pay.php?chapter=24_3
WxApiProfitSharing 🕓 请求单次分账 https://pay.weixin.qq.com/wiki/doc/api/allocation.php?chapter=27_1&index=1
WxApiMultiProfitSharing 🕓 请求多次分账 https://pay.weixin.qq.com/wiki/doc/api/allocation.php?chapter=27_6&index=2
WxApiProfitSharingQuery 🕓 查询分账结果 https://pay.weixin.qq.com/wiki/doc/api/allocation.php?chapter=27_2&index=3
WxApiProfitSharingAddReceiver 🕓 添加分账接收方 https://pay.weixin.qq.com/wiki/doc/api/allocation.php?chapter=27_3&index=4
WxApiProfitSharingRemoveReceiver 🕓 删除分账接收方 https://pay.weixin.qq.com/wiki/doc/api/allocation.php?chapter=27_4&index=5
WxApiProfitSharingFinish 🕓 完结分账 https://pay.weixin.qq.com/wiki/doc/api/allocation.php?chapter=27_5&index=6
WxApiProfitSharingReturn 🕓 分账回退 https://pay.weixin.qq.com/wiki/doc/api/allocation.php?chapter=27_7&index=7
WxApiProfitSharingReturnQuery 🕓 回退结果查询 https://pay.weixin.qq.com/wiki/doc/api/allocation.php?chapter=27_8&index=8
WxNotifyProfitSharing 🕓 分账动账通知 https://pay.weixin.qq.com/wiki/doc/api/allocation.php?chapter=27_9&index=9

支付宝 API

API 完成状态 官网文档地址
AliApiPayApp app支付接口2.0 https://opendocs.alipay.com/apis/api_1/alipay.trade.app.pay
AliApiPayBar (二维码或条码)统一收单交易支付接口 https://opendocs.alipay.com/apis/api_1/alipay.trade.pay
AliApiPayQr (二维码)统一收单线下交易预创建 https://opendocs.alipay.com/apis/api_1/alipay.trade.precreate
AliApiPayWap 手机网站支付接口2.0 https://opendocs.alipay.com/apis/api_1/alipay.trade.wap.pay
AliApiPayWeb PC网站支付 https://opendocs.alipay.com/apis/api_1/alipay.trade.page.pay?scene=API002020081300013629

QQ钱包 API

API 完成状态 官网文档地址
QpayApiPayApp 🕓
QpayApiPayPub 🕓
QpayApiPayQr 🕓
QpayApiPayBar 🕓

招商银行 API

@todo

PalPal API

@todo


安装方式

go get github.com/bennya8/go-union-payment

使用说明

第一步

-- 使用任意一种方式加载 支付网关的配置

a) json

configJson, err: = ioutil.ReadFile("./config.json")
if err != nil {
    t.Error(err)
}
wechatConfig, err: = wechat.NewConfigWithJson(configJson)
if err != nil {
    t.Error(err)
}

b) yaml

configYaml, err: = ioutil.ReadFile("./config.yaml")
if err != nil {
    t.Error(err)
}
wechatConfig, err: = wechat.NewConfigWithYaml(configYaml)
if err != nil {
    t.Error(err)
}

c) struct

wechatConfig: = wechat.Config {
    UseSandbox: false,
    UseBackup: false,
    AppId: "",
    SubAppId: "",
    SubMchId: "",
    MchId: "",
    Md5Key: "",
    AppCertPem: "",
    AppKeyPem: "",
    SignType: "",
    LimitPay: nil,
    FeeType: "",
    ReturnRaw: false,
    NotifyUrl: "",
    RedirectUrl: "",
}

第二步

-- 调用需要的网关API即可获取返回的结果,简单就完成了

// call the gateway channel api
payData: = map[string] string {
    "body": "goods information",
    "subject": "debug goods app payment",
    "trade_no": "xxx" + strconv.Itoa(rand.Intn(99999999)),
    "time_expire": strconv.Itoa(int(time.Now().Unix()) + 600),
    "amount": "0.01",
    "return_param": "anything_you_want",
    "goods_type": "1", // 0 虚拟,1 实物,
    "store_id": "",
}

result: = payment.Invoke(payloads.AliApiPayApp, payData)

if !result.State {
    t.Error(result.Msg)
}
m, e: = result.Data.ToMap()
fmt.Println(m, e)

j, e: = result.Data.ToJson()
fmt.Println(j, e)

x, e: = result.Data.ToXml()
fmt.Println(x, e)

第三步

-- 设置回调通知

接管回调的服务,需要实现IPaymentNotify接口

type AliPaymentService struct {}
func (a *AliPaymentService) PayNotify(gateway payloads.UnionPaymentGateway, notifyData string) {
	if gateway == payloads.AlipayGateway {
		// @todo parse notifyData
		// and maybe change the order status
	} 
}

Iris Framework - Route Context

package notify

import (
	"fmt"
	"github.com/kataras/iris"
	"github.com/kataras/iris/mvc"
)

type PaymentController struct {
}

func (c *PaymentController) BeforeActivation(b mvc.BeforeActivation) {
	b.HandleMany("POST", "/payment/callback", "Callback")
}

func (c *PaymentController) AfterActivation(a mvc.AfterActivation) {
}

func (c *PaymentController) Callback(ctx iris.Context) mvc.Result {
	req := ctx.Request()
    service := &AliPaymentService{}
    payment := go_union_payment.NewUnionPayment(payloads.AlipayGateway, aliConfig)
    payment.ParserNotify(req,service)
}

Build-in net.http Server - http.Request

http.HandleFunc("/your_notify_url", func(w http.ResponseWriter, r *http.Request) {        
    service := &AliPaymentService{}
    payment := go_union_payment.NewUnionPayment(payloads.AlipayGateway, aliConfig)
    payment.ParserNotify(r, service)
})

更多例子

单元测试都会同步在以下目录,供参考

/examples/

第三方依赖包

  • gopkg.in/yaml.v2

LICENSE

MIT