所有URI均基于微信支付 API 地址: https://api.mch.weixin.qq.com
方法名 | HTTP 请求 | 描述 |
---|---|---|
PayReceiptInfo | Get /v3/marketing/busifavor/subsidy/pay-receipts/{subsidy_receipt_id} | 查询商家券营销补差付款单详情 |
PayReceiptList | Get /v3/marketing/busifavor/subsidy/pay-receipts | 查询商家券营销补差付款单列表 |
ReturnReceiptInfo | Get /v3/marketing/busifavor/subsidy/return-receipts/{subsidy_return_receipt_id} | 查询商家券营销补差回退单详情 |
SubsidyPay | Post /v3/marketing/busifavor/subsidy/pay-receipts | 商家券营销补差付款 |
SubsidyReturn | Post /v3/marketing/busifavor/subsidy/return-receipts | 商家券营销补差回退 |
SubsidyPayReceipt PayReceiptInfo(PayReceiptInfoRequest)
查询商家券营销补差付款单详情
package main
import (
"context"
"log"
"git.nanodreamtech.com/sg/wechatpay-go/core"
"git.nanodreamtech.com/sg/wechatpay-go/services/merchantexclusivecoupon"
"git.nanodreamtech.com/sg/wechatpay-go/utils"
)
func main() {
var (
mchID string = "190000****" // 商户号
mchCertificateSerialNumber string = "3775************************************" // 商户证书序列号
mchAPIv3Key string = "2ab9****************************" // 商户APIv3密钥
)
// 使用 utils 提供的函数从本地文件中加载商户私钥,商户私钥会用来生成请求的签名
mchPrivateKey, err := utils.LoadPrivateKeyWithPath("/path/to/merchant/apiclient_key.pem")
if err != nil {
log.Printf("load merchant private key error:%s", err)
return
}
ctx := context.Background()
// 使用商户私钥等初始化 client,并使它具有自动定时获取微信支付平台证书的能力
opts := []core.ClientOption{
option.WithWechatPayAutoAuthCipher(mchID, mchCertificateSerialNumber, mchPrivateKey, mchAPIv3Key),
}
client, err := core.NewClient(ctx, opts...)
if err != nil {
log.Printf("new wechat pay client err:%s", err)
return
}
svc := merchantexclusivecoupon.SubsidyApiService{Client: client}
resp, result, err := svc.PayReceiptInfo(ctx,
merchantexclusivecoupon.PayReceiptInfoRequest{
SubsidyReceiptId: core.String("1120200119165100000000000001"),
},
)
if err != nil {
// 处理错误
log.Printf("call PayReceiptInfo err:%s", err)
} else {
// 处理返回结果
log.Printf("status=%d resp=%s", result.Response.StatusCode, resp)
}
}
参数名 | 参数类型 | 参数描述 |
---|---|---|
ctx | context.Context | Golang 上下文,可用于日志、请求取消、请求跟踪等功能 |
req | PayReceiptInfoRequest | API merchantexclusivecoupon 所定义的本接口需要的所有参数,包括Path /Query /Body 3类参数 |
Name | Type | Description |
---|---|---|
resp | *SubsidyPayReceipt | 结构化的接口返回结果 |
result | *core.APIResult | 本次 API 访问的请求与应答信息 |
err | error | 本次 API 访问中发生的错误,当且仅当 API 失败时存在 |
[返回顶部] [返回接口列表] [返回类型列表] [返回服务README]
SubsidyPayReceiptListResponse PayReceiptList(PayReceiptListRequest)
查询商家券营销补差付款单列表
package main
import (
"context"
"log"
"git.nanodreamtech.com/sg/wechatpay-go/core"
"git.nanodreamtech.com/sg/wechatpay-go/services/merchantexclusivecoupon"
"git.nanodreamtech.com/sg/wechatpay-go/utils"
)
func main() {
var (
mchID string = "190000****" // 商户号
mchCertificateSerialNumber string = "3775************************************" // 商户证书序列号
mchAPIv3Key string = "2ab9****************************" // 商户APIv3密钥
)
// 使用 utils 提供的函数从本地文件中加载商户私钥,商户私钥会用来生成请求的签名
mchPrivateKey, err := utils.LoadPrivateKeyWithPath("/path/to/merchant/apiclient_key.pem")
if err != nil {
log.Printf("load merchant private key error:%s", err)
return
}
ctx := context.Background()
// 使用商户私钥等初始化 client,并使它具有自动定时获取微信支付平台证书的能力
opts := []core.ClientOption{
option.WithWechatPayAutoAuthCipher(mchID, mchCertificateSerialNumber, mchPrivateKey, mchAPIv3Key),
}
client, err := core.NewClient(ctx, opts...)
if err != nil {
log.Printf("new wechat pay client err:%s", err)
return
}
svc := merchantexclusivecoupon.SubsidyApiService{Client: client}
resp, result, err := svc.PayReceiptList(ctx,
merchantexclusivecoupon.PayReceiptListRequest{
StockId: core.String("128888000000001"),
CouponCode: core.String("ABCD12345678"),
OutSubsidyNo: core.String("subsidy-abcd-12345678"),
},
)
if err != nil {
// 处理错误
log.Printf("call PayReceiptList err:%s", err)
} else {
// 处理返回结果
log.Printf("status=%d resp=%s", result.Response.StatusCode, resp)
}
}
参数名 | 参数类型 | 参数描述 |
---|---|---|
ctx | context.Context | Golang 上下文,可用于日志、请求取消、请求跟踪等功能 |
req | PayReceiptListRequest | API merchantexclusivecoupon 所定义的本接口需要的所有参数,包括Path /Query /Body 3类参数 |
Name | Type | Description |
---|---|---|
resp | *SubsidyPayReceiptListResponse | 结构化的接口返回结果 |
result | *core.APIResult | 本次 API 访问的请求与应答信息 |
err | error | 本次 API 访问中发生的错误,当且仅当 API 失败时存在 |
[返回顶部] [返回接口列表] [返回类型列表] [返回服务README]
SubsidyReturnReceipt ReturnReceiptInfo(ReturnReceiptInfoRequest)
查询商家券营销补差回退单详情
package main
import (
"context"
"log"
"git.nanodreamtech.com/sg/wechatpay-go/core"
"git.nanodreamtech.com/sg/wechatpay-go/services/merchantexclusivecoupon"
"git.nanodreamtech.com/sg/wechatpay-go/utils"
)
func main() {
var (
mchID string = "190000****" // 商户号
mchCertificateSerialNumber string = "3775************************************" // 商户证书序列号
mchAPIv3Key string = "2ab9****************************" // 商户APIv3密钥
)
// 使用 utils 提供的函数从本地文件中加载商户私钥,商户私钥会用来生成请求的签名
mchPrivateKey, err := utils.LoadPrivateKeyWithPath("/path/to/merchant/apiclient_key.pem")
if err != nil {
log.Printf("load merchant private key error:%s", err)
return
}
ctx := context.Background()
// 使用商户私钥等初始化 client,并使它具有自动定时获取微信支付平台证书的能力
opts := []core.ClientOption{
option.WithWechatPayAutoAuthCipher(mchID, mchCertificateSerialNumber, mchPrivateKey, mchAPIv3Key),
}
client, err := core.NewClient(ctx, opts...)
if err != nil {
log.Printf("new wechat pay client err:%s", err)
return
}
svc := merchantexclusivecoupon.SubsidyApiService{Client: client}
resp, result, err := svc.ReturnReceiptInfo(ctx,
merchantexclusivecoupon.ReturnReceiptInfoRequest{
SubsidyReturnReceiptId: core.String("2120200119165100000000000001"),
},
)
if err != nil {
// 处理错误
log.Printf("call ReturnReceiptInfo err:%s", err)
} else {
// 处理返回结果
log.Printf("status=%d resp=%s", result.Response.StatusCode, resp)
}
}
参数名 | 参数类型 | 参数描述 |
---|---|---|
ctx | context.Context | Golang 上下文,可用于日志、请求取消、请求跟踪等功能 |
req | ReturnReceiptInfoRequest | API merchantexclusivecoupon 所定义的本接口需要的所有参数,包括Path /Query /Body 3类参数 |
Name | Type | Description |
---|---|---|
resp | *SubsidyReturnReceipt | 结构化的接口返回结果 |
result | *core.APIResult | 本次 API 访问的请求与应答信息 |
err | error | 本次 API 访问中发生的错误,当且仅当 API 失败时存在 |
[返回顶部] [返回接口列表] [返回类型列表] [返回服务README]
SubsidyPayReceipt SubsidyPay(SubsidyPayRequest)
商家券营销补差付款
package main
import (
"context"
"log"
"git.nanodreamtech.com/sg/wechatpay-go/core"
"git.nanodreamtech.com/sg/wechatpay-go/services/merchantexclusivecoupon"
"git.nanodreamtech.com/sg/wechatpay-go/utils"
)
func main() {
var (
mchID string = "190000****" // 商户号
mchCertificateSerialNumber string = "3775************************************" // 商户证书序列号
mchAPIv3Key string = "2ab9****************************" // 商户APIv3密钥
)
// 使用 utils 提供的函数从本地文件中加载商户私钥,商户私钥会用来生成请求的签名
mchPrivateKey, err := utils.LoadPrivateKeyWithPath("/path/to/merchant/apiclient_key.pem")
if err != nil {
log.Printf("load merchant private key error:%s", err)
return
}
ctx := context.Background()
// 使用商户私钥等初始化 client,并使它具有自动定时获取微信支付平台证书的能力
opts := []core.ClientOption{
option.WithWechatPayAutoAuthCipher(mchID, mchCertificateSerialNumber, mchPrivateKey, mchAPIv3Key),
}
client, err := core.NewClient(ctx, opts...)
if err != nil {
log.Printf("new wechat pay client err:%s", err)
return
}
svc := merchantexclusivecoupon.SubsidyApiService{Client: client}
resp, result, err := svc.SubsidyPay(ctx,
merchantexclusivecoupon.SubsidyPayRequest{
StockId: core.String("128888000000001"),
CouponCode: core.String("ABCD12345678"),
TransactionId: core.String("4200000913202101152566792388"),
PayerMerchant: core.String("1900000001"),
PayeeMerchant: core.String("1900000002"),
Amount: core.Int64(100),
Description: core.String("20210115DESCRIPTION"),
OutSubsidyNo: core.String("subsidy-abcd-12345678"),
},
)
if err != nil {
// 处理错误
log.Printf("call SubsidyPay err:%s", err)
} else {
// 处理返回结果
log.Printf("status=%d resp=%s", result.Response.StatusCode, resp)
}
}
参数名 | 参数类型 | 参数描述 |
---|---|---|
ctx | context.Context | Golang 上下文,可用于日志、请求取消、请求跟踪等功能 |
req | SubsidyPayRequest | API merchantexclusivecoupon 所定义的本接口需要的所有参数,包括Path /Query /Body 3类参数 |
Name | Type | Description |
---|---|---|
resp | *SubsidyPayReceipt | 结构化的接口返回结果 |
result | *core.APIResult | 本次 API 访问的请求与应答信息 |
err | error | 本次 API 访问中发生的错误,当且仅当 API 失败时存在 |
[返回顶部] [返回接口列表] [返回类型列表] [返回服务README]
SubsidyReturnReceipt SubsidyReturn(SubsidyReturnRequest)
商家券营销补差回退
package main
import (
"context"
"log"
"git.nanodreamtech.com/sg/wechatpay-go/core"
"git.nanodreamtech.com/sg/wechatpay-go/services/merchantexclusivecoupon"
"git.nanodreamtech.com/sg/wechatpay-go/utils"
)
func main() {
var (
mchID string = "190000****" // 商户号
mchCertificateSerialNumber string = "3775************************************" // 商户证书序列号
mchAPIv3Key string = "2ab9****************************" // 商户APIv3密钥
)
// 使用 utils 提供的函数从本地文件中加载商户私钥,商户私钥会用来生成请求的签名
mchPrivateKey, err := utils.LoadPrivateKeyWithPath("/path/to/merchant/apiclient_key.pem")
if err != nil {
log.Printf("load merchant private key error:%s", err)
return
}
ctx := context.Background()
// 使用商户私钥等初始化 client,并使它具有自动定时获取微信支付平台证书的能力
opts := []core.ClientOption{
option.WithWechatPayAutoAuthCipher(mchID, mchCertificateSerialNumber, mchPrivateKey, mchAPIv3Key),
}
client, err := core.NewClient(ctx, opts...)
if err != nil {
log.Printf("new wechat pay client err:%s", err)
return
}
svc := merchantexclusivecoupon.SubsidyApiService{Client: client}
resp, result, err := svc.SubsidyReturn(ctx,
merchantexclusivecoupon.SubsidyReturnRequest{
StockId: core.String("128888000000001"),
CouponCode: core.String("ABCD12345678"),
TransactionId: core.String("4200000913202101152566792388"),
RefundId: core.String("50100506732021010105138718375"),
PayerMerchant: core.String("1900000001"),
PayeeMerchant: core.String("1900000002"),
Amount: core.Int64(100),
Description: core.String("20210115DESCRIPTION"),
OutSubsidyReturnNo: core.String("subsidy-abcd-12345678"),
},
)
if err != nil {
// 处理错误
log.Printf("call SubsidyReturn err:%s", err)
} else {
// 处理返回结果
log.Printf("status=%d resp=%s", result.Response.StatusCode, resp)
}
}
参数名 | 参数类型 | 参数描述 |
---|---|---|
ctx | context.Context | Golang 上下文,可用于日志、请求取消、请求跟踪等功能 |
req | SubsidyReturnRequest | API merchantexclusivecoupon 所定义的本接口需要的所有参数,包括Path /Query /Body 3类参数 |
Name | Type | Description |
---|---|---|
resp | *SubsidyReturnReceipt | 结构化的接口返回结果 |
result | *core.APIResult | 本次 API 访问的请求与应答信息 |
err | error | 本次 API 访问中发生的错误,当且仅当 API 失败时存在 |