Documentation ¶
Index ¶
- type AuthType
- type CloseReasonType
- type FailReasonType
- type GetTransferBatchByNoRequest
- type GetTransferBatchByOutNoRequest
- type GetTransferDetailByNoRequest
- type GetTransferDetailByOutNoRequest
- type InitiateTransferBatchRequest
- type InitiateTransferBatchResponse
- type TransferBatchApiService
- func (a *TransferBatchApiService) GetTransferBatchByNo(ctx context.Context, req GetTransferBatchByNoRequest) (resp *TransferBatchEntity, result *core.APIResult, err error)
- func (a *TransferBatchApiService) GetTransferBatchByOutNo(ctx context.Context, req GetTransferBatchByOutNoRequest) (resp *TransferBatchEntity, result *core.APIResult, err error)
- func (a *TransferBatchApiService) InitiateTransferBatch(ctx context.Context, req InitiateTransferBatchRequest) (resp *InitiateTransferBatchResponse, result *core.APIResult, err error)
- type TransferBatchEntity
- type TransferDetailApiService
- func (a *TransferDetailApiService) GetTransferDetailByNo(ctx context.Context, req GetTransferDetailByNoRequest) (resp *TransferDetailEntity, result *core.APIResult, err error)
- func (a *TransferDetailApiService) GetTransferDetailByOutNo(ctx context.Context, req GetTransferDetailByOutNoRequest) (resp *TransferDetailEntity, result *core.APIResult, err error)
- type TransferDetailCompact
- type TransferDetailEntity
- type TransferDetailInput
- type TransferScene
- type TransferUseType
Examples ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type AuthType ¶
type AuthType string
AuthType * `INFORMATION_AUTHORIZATION_TYPE` - 特约商户信息授权类型, 表示使用特约商户用户信息,出款方服务商 * `FUND_AUTHORIZATION_TYPE` - 特约商户资金授权类型, 表示使用特约商户的资金,出款方为特约商户,用户信息为服务商appid对应的openid * `INFORMATION_AND_FUND_AUTHORIZATION_TYPE` - 特约商户信息和资金授权类型, 表示使用特约商户的用户信息且出款方为特约商户
type CloseReasonType ¶
type CloseReasonType string
CloseReasonType * `MERCHANT_REVOCATION` - 商户主动撤销, 商户主动撤销(页面方式) * `OVERDUE_CLOSE` - 系统超时关闭, 系统超时关闭,可能原因账户余额不足或其他错误
const ( CLOSEREASONTYPE_MERCHANT_REVOCATION CloseReasonType = "MERCHANT_REVOCATION" CLOSEREASONTYPE_OVERDUE_CLOSE CloseReasonType = "OVERDUE_CLOSE" )
Enums of CloseReasonType
func (CloseReasonType) Ptr ¶
func (e CloseReasonType) Ptr() *CloseReasonType
type FailReasonType ¶
type FailReasonType string
FailReasonType * `ACCOUNT_FROZEN` - 账户冻结, 该用户账户被冻结 * `REAL_NAME_CHECK_FAIL` - 用户未实名, 收款人未实名认证,需要用户完成微信实名认证 * `NAME_NOT_CORRECT` - 用户姓名校验失败, 收款人姓名校验不通过,请核实信息 * `OPENID_INVALID` - Openid校验失败, Openid格式错误或者不属于商家公众账号 * `TRANSFER_QUOTA_EXCEED` - 超过用户单笔收款额度, 超过用户单笔收款额度,核实产品设置是否准确 * `DAY_RECEIVED_QUOTA_EXCEED` - 超过用户单日收款额度, 超过用户单日收款额度,核实产品设置是否准确 * `MONTH_RECEIVED_QUOTA_EXCEED` - 超过用户单月收款额度, 超过用户单月收款额度,核实产品设置是否准确 * `DAY_RECEIVED_COUNT_EXCEED` - 超过用户单日收款次数, 超过用户单日收款次数,核实产品设置是否准确 * `PRODUCT_AUTH_CHECK_FAIL` - 产品权限校验失败, 未开通该权限或权限被冻结,请核实产品权限状态 * `OVERDUE_CLOSE` - 转账关闭, 超过系统重试期,系统自动关闭 * `ID_CARD_NOT_CORRECT` - 用户身份证校验失败, 收款人身份证校验不通过,请核实信息 * `ACCOUNT_NOT_EXIST` - 用户账户不存在, 该用户账户不存在 * `TRANSFER_RISK` - 转账存在风险, 该笔转账可能存在风险,已被微信拦截 * `PAY_ROLL_CARD_ALREADY_LOGOUT` - 用户薪工卡已注销, 该用户的薪工卡已经注销 * `PAY_ROLL_CARD_ALREADY_FROZEN` - 用户薪工卡已冻结, 该用户的薪工卡已经被冻结 * `PAY_ROLL_CARD_UNAUTHORIZED` - 用户薪工卡未授权该商户, 该用户的薪工卡未授权该商户 * `PAY_ROLL_CARD_USER_NOT_OPEN` - 用户未开通薪工卡, 该用户没有开通薪工卡
const ( FAILREASONTYPE_ACCOUNT_FROZEN FailReasonType = "ACCOUNT_FROZEN" FAILREASONTYPE_REAL_NAME_CHECK_FAIL FailReasonType = "REAL_NAME_CHECK_FAIL" FAILREASONTYPE_NAME_NOT_CORRECT FailReasonType = "NAME_NOT_CORRECT" FAILREASONTYPE_OPENID_INVALID FailReasonType = "OPENID_INVALID" FAILREASONTYPE_TRANSFER_QUOTA_EXCEED FailReasonType = "TRANSFER_QUOTA_EXCEED" FAILREASONTYPE_DAY_RECEIVED_QUOTA_EXCEED FailReasonType = "DAY_RECEIVED_QUOTA_EXCEED" FAILREASONTYPE_MONTH_RECEIVED_QUOTA_EXCEED FailReasonType = "MONTH_RECEIVED_QUOTA_EXCEED" FAILREASONTYPE_DAY_RECEIVED_COUNT_EXCEED FailReasonType = "DAY_RECEIVED_COUNT_EXCEED" FAILREASONTYPE_PRODUCT_AUTH_CHECK_FAIL FailReasonType = "PRODUCT_AUTH_CHECK_FAIL" FAILREASONTYPE_OVERDUE_CLOSE FailReasonType = "OVERDUE_CLOSE" FAILREASONTYPE_ID_CARD_NOT_CORRECT FailReasonType = "ID_CARD_NOT_CORRECT" FAILREASONTYPE_ACCOUNT_NOT_EXIST FailReasonType = "ACCOUNT_NOT_EXIST" FAILREASONTYPE_TRANSFER_RISK FailReasonType = "TRANSFER_RISK" FAILREASONTYPE_PAY_ROLL_CARD_ALREADY_LOGOUT FailReasonType = "PAY_ROLL_CARD_ALREADY_LOGOUT" FAILREASONTYPE_PAY_ROLL_CARD_ALREADY_FROZEN FailReasonType = "PAY_ROLL_CARD_ALREADY_FROZEN" FAILREASONTYPE_PAY_ROLL_CARD_UNAUTHORIZED FailReasonType = "PAY_ROLL_CARD_UNAUTHORIZED" FAILREASONTYPE_PAY_ROLL_CARD_USER_NOT_OPEN FailReasonType = "PAY_ROLL_CARD_USER_NOT_OPEN" )
Enums of FailReasonType
func (FailReasonType) Ptr ¶
func (e FailReasonType) Ptr() *FailReasonType
type GetTransferBatchByNoRequest ¶
type GetTransferBatchByNoRequest struct { // 微信支付批次单号,微信商家转账系统返回的唯一标识 BatchId *string `json:"batch_id"` // true-是;false-否,默认否。商户可选择是否查询指定状态的转账明细单,当转账批次单状态为“FINISHED”(已完成)时,才会返回满足条件的转账明细单 NeedQueryDetail *bool `json:"need_query_detail"` // 该次请求资源的起始位置。返回的明细是按照设置的明细条数进行分页展示的,一次查询可能无法返回所有明细,我们使用该参数标识查询开始位置,默认值为0 Offset *int64 `json:"offset,omitempty"` // 该次请求可返回的最大明细条数,最小20条,最大100条,不传则默认20条。不足20条按实际条数返回 Limit *int64 `json:"limit,omitempty"` // 查询指定状态的转账明细单 ALL:全部。需要同时查询转账成功和转账失败的明细单 SUCCESS:转账成功。只查询转账成功的明细单 FAIL:转账失败。只查询转账失败的明细单 DetailStatus *string `json:"detail_status,omitempty"` }
GetTransferBatchByNoRequest
func (GetTransferBatchByNoRequest) Clone ¶
func (o GetTransferBatchByNoRequest) Clone() *GetTransferBatchByNoRequest
func (GetTransferBatchByNoRequest) MarshalJSON ¶
func (o GetTransferBatchByNoRequest) MarshalJSON() ([]byte, error)
func (GetTransferBatchByNoRequest) String ¶
func (o GetTransferBatchByNoRequest) String() string
type GetTransferBatchByOutNoRequest ¶
type GetTransferBatchByOutNoRequest struct { // 商户系统内部的商家批次单号,在商户系统内部唯一 OutBatchNo *string `json:"out_batch_no"` // true-是;false-否,默认否。商户可选择是否查询指定状态的转账明细单,当转账批次单状态为“FINISHED”(已完成)时,才会返回满足条件的转账明细单 NeedQueryDetail *bool `json:"need_query_detail"` // 该次请求资源(转账明细单)的起始位置,从0开始,默认值为0 Offset *int64 `json:"offset,omitempty"` // 该次请求可返回的最大资源(转账明细单)条数,最小20条,最大100条,不传则默认20条。不足20条按实际条数返回 Limit *int64 `json:"limit,omitempty"` // 查询指定状态的转账明细单 ALL:全部。需要同时查询转账成功和转账失败的明细单 SUCCESS:转账成功。只查询转账成功的明细单 FAIL:转账失败。只查询转账失败的明细单 DetailStatus *string `json:"detail_status,omitempty"` }
GetTransferBatchByOutNoRequest
func (GetTransferBatchByOutNoRequest) Clone ¶
func (o GetTransferBatchByOutNoRequest) Clone() *GetTransferBatchByOutNoRequest
func (GetTransferBatchByOutNoRequest) MarshalJSON ¶
func (o GetTransferBatchByOutNoRequest) MarshalJSON() ([]byte, error)
func (GetTransferBatchByOutNoRequest) String ¶
func (o GetTransferBatchByOutNoRequest) String() string
type GetTransferDetailByNoRequest ¶
type GetTransferDetailByNoRequest struct { // 微信支付批次单号,微信商家转账系统返回的唯一标识 BatchId *string `json:"batch_id"` // 微信支付系统内部区分转账批次单下不同转账明细单的唯一标识 DetailId *string `json:"detail_id"` }
GetTransferDetailByNoRequest
func (GetTransferDetailByNoRequest) Clone ¶
func (o GetTransferDetailByNoRequest) Clone() *GetTransferDetailByNoRequest
func (GetTransferDetailByNoRequest) MarshalJSON ¶
func (o GetTransferDetailByNoRequest) MarshalJSON() ([]byte, error)
func (GetTransferDetailByNoRequest) String ¶
func (o GetTransferDetailByNoRequest) String() string
type GetTransferDetailByOutNoRequest ¶
type GetTransferDetailByOutNoRequest struct { // 商户系统内部的商家批次单号,在商户系统内部唯一 OutBatchNo *string `json:"out_batch_no"` // 商户系统内部区分转账批次单下不同转账明细单的唯一标识 OutDetailNo *string `json:"out_detail_no"` }
GetTransferDetailByOutNoRequest
func (GetTransferDetailByOutNoRequest) Clone ¶
func (o GetTransferDetailByOutNoRequest) Clone() *GetTransferDetailByOutNoRequest
func (GetTransferDetailByOutNoRequest) MarshalJSON ¶
func (o GetTransferDetailByOutNoRequest) MarshalJSON() ([]byte, error)
func (GetTransferDetailByOutNoRequest) String ¶
func (o GetTransferDetailByOutNoRequest) String() string
type InitiateTransferBatchRequest ¶
type InitiateTransferBatchRequest struct { // 特约商户号 SubMchid *string `json:"sub_mchid"` // 微信分配的特约商户公众账号ID,特约商户授权类型为INFORMATION_AUTHORIZATION_TYPE和INFORMATION_AND_FUND_AUTHORIZATION_TYPE时 需要填写 SubAppid *string `json:"sub_appid,omitempty"` // 特约商户授权类型 * `INFORMATION_AUTHORIZATION_TYPE` - 特约商户信息授权类型 * `FUND_AUTHORIZATION_TYPE` - 特约商户资金授权类型 * `INFORMATION_AND_FUND_AUTHORIZATION_TYPE` - 特约商户信息和资金授权类型 AuthorizationType *AuthType `json:"authorization_type"` // 商户系统内部的商家批次单号,在商户系统内部唯一 OutBatchNo *string `json:"out_batch_no"` // 该笔批量转账的名称 BatchName *string `json:"batch_name"` // 转账说明,UTF8编码,最多允许32个字符 BatchRemark *string `json:"batch_remark"` // 转账金额单位为“分”。转账总金额必须与批次内所有明细转账金额之和保持一致,否则无法发起转账操作 TotalAmount *int64 `json:"total_amount"` // 一个转账批次单最多发起三千笔转账。转账总笔数必须与批次内所有明细之和保持一致,否则无法发起转账操作 TotalNum *int64 `json:"total_num"` // 发起批量转账的明细列表,最多三千笔 TransferDetailList []TransferDetailInput `json:"transfer_detail_list,omitempty"` // 微信分配的服务商商户公众账号ID,特约商户授权类型为FUND_AUTHORIZATION_TYPE时 需要填写 SpAppid *string `json:"sp_appid,omitempty"` // 批量转账用途 * `GOODSPAYMENT` - 货款 * `COMMISSION` - 佣金 * `REFUND` - 退款 * `REIMBURSEMENT` - 报销 * `FREIGHT` - 运费 * `OTHERS` - 其他 TransferPurpose *TransferUseType `json:"transfer_purpose,omitempty"` // 商户的转账场景 * `ORDINARY_TRANSFER` - 普通转账 * `PAYROLL_CARD_TRANSFER` - 薪工卡转账 TransferScene *TransferScene `json:"transfer_scene,omitempty"` }
InitiateTransferBatchRequest
func (InitiateTransferBatchRequest) Clone ¶
func (o InitiateTransferBatchRequest) Clone() *InitiateTransferBatchRequest
func (InitiateTransferBatchRequest) MarshalJSON ¶
func (o InitiateTransferBatchRequest) MarshalJSON() ([]byte, error)
func (InitiateTransferBatchRequest) String ¶
func (o InitiateTransferBatchRequest) String() string
type InitiateTransferBatchResponse ¶
type InitiateTransferBatchResponse struct { // 商户系统内部的商家批次单号,在商户系统内部唯一 OutBatchNo *string `json:"out_batch_no"` // 微信支付批次单号,微信商家转账系统返回的唯一标识 BatchId *string `json:"batch_id"` // 批次受理成功时返回,按照使用rfc3339所定义的格式,格式为YYYY-MM-DDThh:mm:ss+TIMEZONE CreateTime *time.Time `json:"create_time"` }
InitiateTransferBatchResponse
func (InitiateTransferBatchResponse) Clone ¶
func (o InitiateTransferBatchResponse) Clone() *InitiateTransferBatchResponse
func (InitiateTransferBatchResponse) MarshalJSON ¶
func (o InitiateTransferBatchResponse) MarshalJSON() ([]byte, error)
func (InitiateTransferBatchResponse) String ¶
func (o InitiateTransferBatchResponse) String() string
type TransferBatchApiService ¶
func (*TransferBatchApiService) GetTransferBatchByNo ¶
func (a *TransferBatchApiService) GetTransferBatchByNo(ctx context.Context, req GetTransferBatchByNoRequest) (resp *TransferBatchEntity, result *core.APIResult, err error)
GetTransferBatchByNo 微信支付批次单号查询批次单
## 查询接口说明 微信支付批次单号查单接口。转账处理后延迟一段时间(异步进行转账),服务商可以通过该接口查询转账批次单以及指定状态的转账明细单。返回消息中包含微信支付批次单号、批次状态、批次类型、转账总金额、转账总笔数、成功金额、失败金额等信息。
接口限频: 单个服务商(查询转账批次单)50QPS,如果超过频率限制,会报错FREQUENCY_LIMITED,请降低频率请求。
注意事项: - API只支持查询最近30天内的转账批次单,30天之前的转账批次单请登录商户平台查询。 - 转账明细单只会在批次单完成的情况下返回,如果需要在批次处理过程中查询转账明细单,请通过转账明细单查询接口来查询。 - 转账批次单和明细单中涉及金额的字段单位为“分”。 - 如果查询单号对应的数据不存在,那么数据不存在的原因可能是:(1)批次还在受理中;(2)批次受理失败导致转账批次单没有落地。在上述情况下,服务商首先需要检查该微信支付批次单号是否确实是自己发起的,如果服务商确认是自己发起的,则请服务商不要直接当做受理失败处理,请服务商隔几分钟再尝试查询(请勿转账和查询并发处理),或者服务商可以通过相同的商家批次单号再次发起转账。如果服务商误把还在受理中的批次单直接当受理失败处理,服务商应当自行承担因此产生的所有损失和责任。 - 如果遇到回包返回新的错误码,请务必不要换单重试,请联系客服确认转账情况。如果有新的错误码,会更新到此API文档中。 - 错误码描述字段message只供人工定位问题时做参考,系统实现时请不要依赖这个字段来做自动化处理。
Example ¶
package main import ( "context" "log" "github.com/Marek-maxs/wechatpay-go/core" "github.com/Marek-maxs/wechatpay-go/core/option" "github.com/Marek-maxs/wechatpay-go/services/partnertransferbatch" "github.com/Marek-maxs/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.Print("load merchant private key error") } 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) } svc := partnertransferbatch.TransferBatchApiService{Client: client} resp, result, err := svc.GetTransferBatchByNo(ctx, partnertransferbatch.GetTransferBatchByNoRequest{ BatchId: core.String("1030000071100999991182020050700019480001"), NeedQueryDetail: core.Bool(true), Offset: core.Int64(0), Limit: core.Int64(20), DetailStatus: core.String("FAIL"), }, ) if err != nil { // 处理错误 log.Printf("call GetTransferBatchByNo err:%s", err) } else { // 处理返回结果 log.Printf("status=%d resp=%s", result.Response.StatusCode, resp) } }
Output:
func (*TransferBatchApiService) GetTransferBatchByOutNo ¶
func (a *TransferBatchApiService) GetTransferBatchByOutNo(ctx context.Context, req GetTransferBatchByOutNoRequest) (resp *TransferBatchEntity, result *core.APIResult, err error)
GetTransferBatchByOutNo 商家批次单号查询批次单
## 查询接口说明 商家批次单号查单接口。转账处理后延迟一段时间(异步进行转账),服务商可以通过该接口查询转账批次单以及指定状态的转账明细单。返回消息中包含微信支付批次单号、批次状态、批次类型、转账总金额、转账总笔数、成功金额、失败金额等信息。
接口限频: 单个服务商(查询转账批次单)50QPS,如果超过频率限制,会报错FREQUENCY_LIMITED,请降低频率请求。
注意事项: - API只支持查询最近30天内的转账批次单,30天之前的转账批次单请登录商户平台查询。 - 转账明细单只会在批次单完成的情况下返回,如果需要在批次处理过程中查询转账明细单,请通过转账明细单查询接口来查询。 - 转账批次单和明细单中涉及金额的字段单位为“分”。 - 如果查询单号对应的数据不存在,那么数据不存在的原因可能是:(1)批次还在受理中;(2)批次受理失败导致转账批次单没有落地。在上述情况下,服务商首先需要检查该商家批次单号是否确实是自己发起的,如果服务商确认是自己发起的,则请服务商不要直接当做受理失败处理,请服务商隔几分钟再尝试查询(请勿转账和查询并发处理),或者服务商可以通过相同的商家批次单号再次发起转账。如果服务商误把还在受理中的批次单直接当受理失败处理,服务商应当自行承担因此产生的所有损失和责任。 - 如果遇到回包返回新的错误码,请务必不要换单重试,请联系客服确认转账情况。如果有新的错误码,会更新到此API文档中。 - 错误码描述字段message只供人工定位问题时做参考,系统实现时请不要依赖这个字段来做自动化处理。
Example ¶
package main import ( "context" "log" "github.com/Marek-maxs/wechatpay-go/core" "github.com/Marek-maxs/wechatpay-go/core/option" "github.com/Marek-maxs/wechatpay-go/services/partnertransferbatch" "github.com/Marek-maxs/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.Print("load merchant private key error") } 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) } svc := partnertransferbatch.TransferBatchApiService{Client: client} resp, result, err := svc.GetTransferBatchByOutNo(ctx, partnertransferbatch.GetTransferBatchByOutNoRequest{ OutBatchNo: core.String("plfk2020042013"), NeedQueryDetail: core.Bool(true), Offset: core.Int64(0), Limit: core.Int64(20), DetailStatus: core.String("FAIL"), }, ) if err != nil { // 处理错误 log.Printf("call GetTransferBatchByOutNo err:%s", err) } else { // 处理返回结果 log.Printf("status=%d resp=%s", result.Response.StatusCode, resp) } }
Output:
func (*TransferBatchApiService) InitiateTransferBatch ¶
func (a *TransferBatchApiService) InitiateTransferBatch(ctx context.Context, req InitiateTransferBatchRequest) (resp *InitiateTransferBatchResponse, result *core.APIResult, err error)
InitiateTransferBatch 发起批量转账
## 发起批量转账 服务商可以通过该接口,批量向用户零钱进行转账操作。请求消息中应包含特约商户号、特约商户授权的appid、授权类型、商家批次单号、转账名称、转账总金额、转账总笔数、转账openid、收款用户姓名、服务商appid、转账用途等信息 1、当特约商户授权类型为INFORMATION_AUTHORIZATION_TYPE(特约商户信息授权),需要填特约商户的公众号appid,特约商户公众号appid的用户的openid 2、当特约商户授权类型为FUND_AUTHORIZATION_TYPE(特约商户资金授权),需要填服务商的公众号appid,服务商公众号appid的用户的openid
接口限频: 单个服务商(发起批量转账接口)50QPS,如果超过频率限制,会报错FREQUENCY_LIMITED,请降低频率请求。
注意事项: - 因服务商自身系统设置存在问题导致的资金损失,由服务商自行承担。 - 批量转账一旦发起后,不允许撤销。 - 转账批次单和明细单中涉及金额的字段单位为“分”。 - 微信支付视任何不同“发起的服务商商户号+商家批次单号(out_batch_no)”的请求为一个全新的批次。在未查询到明确的转账批次单处理结果之前,请勿修改商家批次单号重新提交!如有发生,服务商应当自行承担因此产生的所有损失和责任。 - 当返回错误时,请不要更换商家批次单号,一定要使用原商家批次单号重试,否则可能造成重复转账等资金风险。 - 如果遇到回包返回新的错误码,请务必不要换单重试,请联系客服确认转账情况。如果有新的错误码,会更新到此API文档中。 - 错误码描述字段message只供人工定位问题时做参考,系统实现时请不要依赖这个字段来做自动化处理。 - 请服务商在自身的系统中合理设置转账频次并做好并发控制,防范错付风险。
Example ¶
package main import ( "context" "log" "github.com/Marek-maxs/wechatpay-go/core" "github.com/Marek-maxs/wechatpay-go/core/option" "github.com/Marek-maxs/wechatpay-go/services/partnertransferbatch" "github.com/Marek-maxs/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.Print("load merchant private key error") } 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) } svc := partnertransferbatch.TransferBatchApiService{Client: client} resp, result, err := svc.InitiateTransferBatch(ctx, partnertransferbatch.InitiateTransferBatchRequest{ SubMchid: core.String("1900000109"), SubAppid: core.String("wxf636efh567hg4356"), AuthorizationType: partnertransferbatch.AUTHTYPE_INFORMATION_AUTHORIZATION_TYPE.Ptr(), OutBatchNo: core.String("plfk2020042013"), BatchName: core.String("2019年1月深圳分部报销单"), BatchRemark: core.String("2019年1月深圳分部报销单"), TotalAmount: core.Int64(4000000), TotalNum: core.Int64(200), TransferDetailList: []partnertransferbatch.TransferDetailInput{partnertransferbatch.TransferDetailInput{ Openid: core.String("o-MYE42l80oelYMDE34nYD456Xoy"), OutDetailNo: core.String("x23zy545Bd5436"), TransferAmount: core.Int64(200000), TransferRemark: core.String("2020年4月报销"), UserIdCard: core.String("UserIdCard_example"), UserName: core.String("UserName_example"), }}, SpAppid: core.String("wxf636efh567hg4388"), TransferPurpose: partnertransferbatch.TRANSFERUSETYPE_GOODSPAYMENT.Ptr(), TransferScene: partnertransferbatch.TRANSFERSCENE_ORDINARY_TRANSFER.Ptr(), }, ) if err != nil { // 处理错误 log.Printf("call InitiateTransferBatch err:%s", err) } else { // 处理返回结果 log.Printf("status=%d resp=%s", result.Response.StatusCode, resp) } }
Output:
type TransferBatchEntity ¶
type TransferBatchEntity struct { // 微信支付分配的服务商商户号 SpMchid *string `json:"sp_mchid"` // 微信支付分配的特约商户号 SubMchid *string `json:"sub_mchid"` // 商户系统内部的商家批次单号,在商户系统内部唯一 OutBatchNo *string `json:"out_batch_no"` // 微信支付批次单号,微信商家转账系统返回的唯一标识 BatchId *string `json:"batch_id"` // 微信分配的特约商户公众账号ID。特约商户appid SubAppid *string `json:"sub_appid,omitempty"` // WAIT_PAY:待付款,商户员工确认付款阶段。ACCEPTED:已受理。批次已受理成功,若发起批量转账的30分钟后,转账批次单仍处于该状态,可能原因是商户账户余额不足等。商户可查询账户资金流水,若该笔转账批次单的扣款已经发生,则表示批次已经进入转账中,请再次查单确认 PROCESSING:转账中。已开始处理批次内的转账明细单 FINISHED:已完成。批次内的所有转账明细单都已处理完成 CLOSED:已关闭。可查询具体的批次关闭原因确认 BatchStatus *string `json:"batch_status"` // API:API方式发起 WEB:页面方式发起 BatchType *string `json:"batch_type"` // 特约商户授权类型 * `INFORMATION_AUTHORIZATION_TYPE` - 特约商户信息授权类型 * `FUND_AUTHORIZATION_TYPE` - 特约商户资金授权类型 * `INFORMATION_AND_FUND_AUTHORIZATION_TYPE` - 特约商户信息和资金授权类型 AuthorizationType *AuthType `json:"authorization_type"` // 该笔批量转账的名称 BatchName *string `json:"batch_name"` // 转账说明,UTF8编码,最多允许32个字符 BatchRemark *string `json:"batch_remark"` // 如果批次单状态为“CLOSED”(已关闭),则有关闭原因 * `MERCHANT_REVOCATION` - 商户主动撤销 * `OVERDUE_CLOSE` - 系统超时关闭 CloseReason *CloseReasonType `json:"close_reason,omitempty"` // 转账金额单位为“分” TotalAmount *int64 `json:"total_amount"` // 一个转账批次单最多发起三千笔转账 TotalNum *int64 `json:"total_num"` // 批次受理成功时返回,按照使用rfc3339所定义的格式,格式为YYYY-MM-DDThh:mm:ss+TIMEZONE CreateTime *time.Time `json:"create_time,omitempty"` // 批次最近一次状态变更的时间,按照使用rfc3339所定义的格式,格式为YYYY-MM-DDThh:mm:ss+TIMEZONE UpdateTime *time.Time `json:"update_time,omitempty"` // 转账成功的金额,单位为“分”。当批次状态为“PROCESSING”(转账中)时,转账成功金额随时可能变化 SuccessAmount *int64 `json:"success_amount,omitempty"` // 转账成功的笔数。当批次状态为“PROCESSING”(转账中)时,转账成功笔数随时可能变化 SuccessNum *int64 `json:"success_num,omitempty"` // 转账失败的金额,单位为“分” FailAmount *int64 `json:"fail_amount,omitempty"` // 转账失败的笔数 FailNum *int64 `json:"fail_num,omitempty"` // 当批次状态为“FINISHED”(已完成),且成功查询到转账明细单时返回。包括微信明细单号、明细状态信息 TransferDetailList []TransferDetailCompact `json:"transfer_detail_list,omitempty"` // 微信分配的服务商商户公众账号ID,特约商户授权类型为FUND_AUTHORIZATION_TYPE时才有该字段 SpAppid *string `json:"sp_appid,omitempty"` // 批量转账用途 * `GOODSPAYMENT` - 货款 * `COMMISSION` - 佣金 * `REFUND` - 退款 * `REIMBURSEMENT` - 报销 * `FREIGHT` - 运费 * `OTHERS` - 其他 TransferPurpose *TransferUseType `json:"transfer_purpose,omitempty"` // 商户的转账场景 * `ORDINARY_TRANSFER` - 普通转账 * `PAYROLL_CARD_TRANSFER` - 薪工卡转账 TransferScene *TransferScene `json:"transfer_scene,omitempty"` }
TransferBatchEntity
func (TransferBatchEntity) Clone ¶
func (o TransferBatchEntity) Clone() *TransferBatchEntity
func (TransferBatchEntity) MarshalJSON ¶
func (o TransferBatchEntity) MarshalJSON() ([]byte, error)
func (TransferBatchEntity) String ¶
func (o TransferBatchEntity) String() string
type TransferDetailApiService ¶
func (*TransferDetailApiService) GetTransferDetailByNo ¶
func (a *TransferDetailApiService) GetTransferDetailByNo(ctx context.Context, req GetTransferDetailByNoRequest) (resp *TransferDetailEntity, result *core.APIResult, err error)
GetTransferDetailByNo 微信支付明细单号查询明细单
## 查询接口说明 微信支付明细单号查单接口。转账处理后延迟一段时间(异步进行转账),服务商可以通过该接口查询单笔转账明细单。返回消息中包含微信支付明细单号、明细状态、转账金额、失败原因、收款用户姓名、用户OpenID等信息。
接口限频: 单个服务商(查询转账明细单)50QPS,如果超过频率限制,会报错FREQUENCY_LIMITED,请降低频率请求。
注意事项: - API只支持查询最近30天内的转账明细单,30天之前的转账明细单请登录商户平台查询。 - 转账明细单中涉及金额的字段单位为“分”。 - 如果查询单号对应的数据不存在,那么数据不存在的原因可能是:(1)转账还在处理中;(2)转账批次单受理失败或还未开始处理导致转账明细单没有落地。在上述情况下,服务商首先需要检查该微信支付明细单号是否确实是自己发起,以及是否是该批次下的,如果服务商确认是自己发起且是该批次下的,则请服务商不要直接当做转账失败处理,请服务商隔几分钟再尝试查询(请勿转账和查询并发处理)。如果服务商误把还在转账处理中的明细单直接当转账失败处理,服务商应当自行承担因此产生的所有损失和责任。 - 如果遇到回包返回新的错误码,请务必不要换单重试,请联系客服确认转账情况。如果有新的错误码,会更新到此API文档中。 - 错误码描述字段message只供人工定位问题时做参考,系统实现时请不要依赖这个字段来做自动化处理。
Example ¶
package main import ( "context" "log" "github.com/Marek-maxs/wechatpay-go/core" "github.com/Marek-maxs/wechatpay-go/core/option" "github.com/Marek-maxs/wechatpay-go/services/partnertransferbatch" "github.com/Marek-maxs/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.Print("load merchant private key error") } 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) } svc := partnertransferbatch.TransferDetailApiService{Client: client} resp, result, err := svc.GetTransferDetailByNo(ctx, partnertransferbatch.GetTransferDetailByNoRequest{ BatchId: core.String("1030000071100999991182020050700019480001"), DetailId: core.String("1040000071100999991182020050700019500100"), }, ) if err != nil { // 处理错误 log.Printf("call GetTransferDetailByNo err:%s", err) } else { // 处理返回结果 log.Printf("status=%d resp=%s", result.Response.StatusCode, resp) } }
Output:
func (*TransferDetailApiService) GetTransferDetailByOutNo ¶
func (a *TransferDetailApiService) GetTransferDetailByOutNo(ctx context.Context, req GetTransferDetailByOutNoRequest) (resp *TransferDetailEntity, result *core.APIResult, err error)
GetTransferDetailByOutNo 商家明细单号查询明细单
## 查询接口说明 商户明细单号查单接口。转账处理后延迟一段时间(异步进行转账),服务商可以通过该接口查询单笔转账明细单。返回消息中包含微信明细单号、明细状态、转账金额、失败原因、收款用户姓名、用户OpenID等信息。
接口限频: 单个服务商(查询转账明细单)50QPS,如果超过频率限制,会报错FREQUENCY_LIMITED,请降低频率请求。
注意事项: - API只支持查询最近30天内的转账明细单,30天之前的转账明细单请登录商户平台查询。 - 转账明细单中涉及金额的字段单位为“分”。 - 如果查询单号对应的数据不存在,那么数据不存在的原因可能是:(1)转账还在处理中;(2)转账批次单受理失败或还未开始处理导致转账明细单没有落地。在上述情况下,服务商首先需要检查该商家明细单号是否确实是自己发起,以及是否是该批次下的,如果服务商确认是自己发起且是该批次下的,则请服务商不要直接当做转账失败处理,请服务商隔几分钟再尝试查询(请勿转账和查询并发处理)。如果服务商误把还在转账处理中的明细单直接当转账失败处理,服务商应当自行承担因此产生的所有损失和责任。 - 如果遇到回包返回新的错误码,请务必不要换单重试,请联系客服确认转账情况。如果有新的错误码,会更新到此API文档中。 - 错误码描述字段message只供人工定位问题时做参考,系统实现时请不要依赖这个字段来做自动化处理。
Example ¶
package main import ( "context" "log" "github.com/Marek-maxs/wechatpay-go/core" "github.com/Marek-maxs/wechatpay-go/core/option" "github.com/Marek-maxs/wechatpay-go/services/partnertransferbatch" "github.com/Marek-maxs/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.Print("load merchant private key error") } 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) } svc := partnertransferbatch.TransferDetailApiService{Client: client} resp, result, err := svc.GetTransferDetailByOutNo(ctx, partnertransferbatch.GetTransferDetailByOutNoRequest{ OutBatchNo: core.String("plfk2020042013"), OutDetailNo: core.String("x23zy545Bd5436"), }, ) if err != nil { // 处理错误 log.Printf("call GetTransferDetailByOutNo err:%s", err) } else { // 处理返回结果 log.Printf("status=%d resp=%s", result.Response.StatusCode, resp) } }
Output:
type TransferDetailCompact ¶
type TransferDetailCompact struct { // 微信支付系统内部区分转账批次单下不同转账明细单的唯一标识 DetailId *string `json:"detail_id"` // 商户系统内部区分转账批次单下不同转账明细单的唯一标识 OutDetailNo *string `json:"out_detail_no"` // PROCESSING:转账中。正在处理中,转账结果尚未明确 SUCCESS:转账成功 FAIL:转账失败。需要确认失败原因后,再决定是否重新发起对该笔明细单的转账(并非整个转账批次单) DetailStatus *string `json:"detail_status"` }
TransferDetailCompact
func (TransferDetailCompact) Clone ¶
func (o TransferDetailCompact) Clone() *TransferDetailCompact
func (TransferDetailCompact) MarshalJSON ¶
func (o TransferDetailCompact) MarshalJSON() ([]byte, error)
func (TransferDetailCompact) String ¶
func (o TransferDetailCompact) String() string
type TransferDetailEntity ¶
type TransferDetailEntity struct { // 微信支付分配的商户号,此处为服务商商户号 SpMchid *string `json:"sp_mchid"` // 商户系统内部的商家批次单号,在商户系统内部唯一 OutBatchNo *string `json:"out_batch_no"` // 微信支付批次单号,微信商家转账系统返回的唯一标识 BatchId *string `json:"batch_id"` // 微信分配的商户公众账号ID。特约商户授权类型为INFORMATION_AUTHORIZATION_TYPE和INFORMATION_AND_FUND_AUTHORIZATION_TYPE时对应的是特约商户的appid,特约商户授权类型为FUND_AUTHORIZATION_TYPE时为服务商的appid Appid *string `json:"appid,omitempty"` // 商户系统内部区分转账批次单下不同转账明细单的唯一标识 OutDetailNo *string `json:"out_detail_no"` // 微信支付系统内部区分转账批次单下不同转账明细单的唯一标识 DetailId *string `json:"detail_id"` // PROCESSING:转账中。正在处理中,转账结果尚未明确 SUCCESS:转账成功 FAIL:转账失败。需要确认失败原因后,再决定是否重新发起对该笔明细单的转账(并非整个转账批次单) DetailStatus *string `json:"detail_status"` // 转账金额单位为“分” TransferAmount *int64 `json:"transfer_amount"` // 单条转账备注(微信用户会收到该备注),UTF8编码,最多允许32个字符 TransferRemark *string `json:"transfer_remark"` // 如果转账失败则有失败原因 * `ACCOUNT_FROZEN` - 账户冻结 * `REAL_NAME_CHECK_FAIL` - 用户未实名 * `NAME_NOT_CORRECT` - 用户姓名校验失败 * `OPENID_INVALID` - Openid校验失败 * `TRANSFER_QUOTA_EXCEED` - 超过用户单笔收款额度 * `DAY_RECEIVED_QUOTA_EXCEED` - 超过用户单日收款额度 * `MONTH_RECEIVED_QUOTA_EXCEED` - 超过用户单月收款额度 * `DAY_RECEIVED_COUNT_EXCEED` - 超过用户单日收款次数 * `PRODUCT_AUTH_CHECK_FAIL` - 产品权限校验失败 * `OVERDUE_CLOSE` - 转账关闭 * `ID_CARD_NOT_CORRECT` - 用户身份证校验失败 * `ACCOUNT_NOT_EXIST` - 用户账户不存在 * `TRANSFER_RISK` - 转账存在风险 * `PAY_ROLL_CARD_ALREADY_LOGOUT` - 用户薪工卡已注销 * `PAY_ROLL_CARD_ALREADY_FROZEN` - 用户薪工卡已冻结 * `PAY_ROLL_CARD_UNAUTHORIZED` - 用户薪工卡未授权该商户 * `PAY_ROLL_CARD_USER_NOT_OPEN` - 用户未开通薪工卡 FailReason *FailReasonType `json:"fail_reason,omitempty"` // 收款用户openid。如果转账特约商户授权类型是INFORMATION_AUTHORIZATION_TYPE,对应的是特约商户公众号下的openid;如果转账特约商户授权类型是FUND_AUTHORIZATION_TYPE,对应的是服务商商户公众号下的openid。 Openid *string `json:"openid"` // 收款方姓名。采用标准RSA算法,公钥由微信侧提供 Username *string `json:"username" encryption:"EM_APIV3"` // 转账发起的时间,按照使用rfc3339所定义的格式,格式为YYYY-MM-DDThh:mm:ss+TIMEZONE InitiateTime *time.Time `json:"initiate_time"` // 明细最后一次状态变更的时间,按照使用rfc3339所定义的格式,格式为YYYY-MM-DDThh:mm:ss+TIMEZONE UpdateTime *time.Time `json:"update_time"` }
TransferDetailEntity
func (TransferDetailEntity) Clone ¶
func (o TransferDetailEntity) Clone() *TransferDetailEntity
func (TransferDetailEntity) MarshalJSON ¶
func (o TransferDetailEntity) MarshalJSON() ([]byte, error)
func (TransferDetailEntity) String ¶
func (o TransferDetailEntity) String() string
type TransferDetailInput ¶
type TransferDetailInput struct { // 商户系统内部区分转账批次单下不同转账明细单的唯一标识 OutDetailNo *string `json:"out_detail_no"` // 转账金额单位为“分” TransferAmount *int64 `json:"transfer_amount"` // 单条转账备注(微信用户会收到该备注),UTF8编码,最多允许32个字符 TransferRemark *string `json:"transfer_remark"` // 收款用户openid。如果转账特约商户授权类型是INFORMATION_AUTHORIZATION_TYPE,对应的是特约商户公众号下的openid。 Openid *string `json:"openid"` // 收款用户姓名。采用标准RSA算法,公钥由微信侧提供 UserName *string `json:"user_name" encryption:"EM_APIV3"` // 收款方身份证号,可不用填(采用标准RSA算法,公钥由微信侧提供) UserIdCard *string `json:"user_id_card,omitempty" encryption:"EM_APIV3"` }
TransferDetailInput
func (TransferDetailInput) Clone ¶
func (o TransferDetailInput) Clone() *TransferDetailInput
func (TransferDetailInput) MarshalJSON ¶
func (o TransferDetailInput) MarshalJSON() ([]byte, error)
func (TransferDetailInput) String ¶
func (o TransferDetailInput) String() string
type TransferScene ¶
type TransferScene string
TransferScene * `ORDINARY_TRANSFER` - 普通转账, 普通转账(默认) * `PAYROLL_CARD_TRANSFER` - 薪工卡转账, 给使用微信薪工卡的用户进行转账
const ( TRANSFERSCENE_ORDINARY_TRANSFER TransferScene = "ORDINARY_TRANSFER" TRANSFERSCENE_PAYROLL_CARD_TRANSFER TransferScene = "PAYROLL_CARD_TRANSFER" )
Enums of TransferScene
func (TransferScene) Ptr ¶
func (e TransferScene) Ptr() *TransferScene
type TransferUseType ¶
type TransferUseType string
TransferUseType * `GOODSPAYMENT` - 货款, 给用户支付货物采购资金 * `COMMISSION` - 佣金, 给用户支付业务推广佣金 * `REFUND` - 退款, 给用户支付交易退款 * `REIMBURSEMENT` - 报销, 企业给员工支付差旅等报销资金 * `FREIGHT` - 运费, 给司机支付运输费用 * `OTHERS` - 其他, 其他
const ( TRANSFERUSETYPE_GOODSPAYMENT TransferUseType = "GOODSPAYMENT" TRANSFERUSETYPE_COMMISSION TransferUseType = "COMMISSION" TRANSFERUSETYPE_REFUND TransferUseType = "REFUND" TRANSFERUSETYPE_REIMBURSEMENT TransferUseType = "REIMBURSEMENT" TRANSFERUSETYPE_FREIGHT TransferUseType = "FREIGHT" TRANSFERUSETYPE_OTHERS TransferUseType = "OTHERS" )
Enums of TransferUseType
func (TransferUseType) Ptr ¶
func (e TransferUseType) Ptr() *TransferUseType