Skip to content

微信支付入门

在使用之前,请先阅读官方文档API V3 了解微信支付的大致工作流程。

微信支付是独立的一个服务,能够支持公众号、小程序、JSSDK、企业微信支付等平台,所以我们这边Payment拆分成了一个单独的实例。

Payment实例初始化

go

PaymentService, err := payment.NewPayment(&payment.UserConfig{
  AppID:              "[app_id]",                 // 小程序、公众号或者企业微信的appid
  MchID:              "[mch_id]",                 // 商户号 appID
  MchApiV3Key:        "[mch_api_v3_key]",         // 微信V3接口调用必填
  Key:                "[key]",                    // 微信V2接口调用必填
  CertPath:           "[wx_cert_path]",           // 商户后台支付的Cert证书路径
  KeyPath:            "[wx_key_path]",            // 商户后台支付的Key证书路径
  SerialNo:           "[serial_no]",              // 商户支付证书序列号
  WechatPaySerial:    "[wechat_pay_serial]",      // 微信支付平台证书序列号[选填]
  CertificateKeyPath: "[certificate_key_path]",   // 微信支付平台证书路径,[选填]
  RSAPublicKeyPath:   "[wx_rsa_public_key_path]", // 微信支付平台证书的Key证书路径[选填]
  SubMchID:           "[sub_mch_id]",             // 服务商平台下的子商户号Id,[选填]
  SubAppID:           "[syb_appid]",              // 服务商平台下的子AppId,[选填]
  NotifyURL:          "[notify_url]",
  HttpDebug:          true,
  Log: payment.Log{
    Level: "debug",
    // 可以重定向到你的目录下,如果设置File和Error,默认会在当前目录下的wechat文件夹下生成日志
    File:  "/Users/user/wechat/payment/info.log", 
	  Error: "/Users/user/wechat/payment/error.log",
    Stdout: false, //  是否打印在终端
  },
  Http: payment.Http{
    Timeout: 30.0,
    BaseURI: "https://api.mch.weixin.qq.com",
  },
  // 可选,不传默认走程序内存
  Cache: kernel.NewRedisClient(&kernel.UniversalOptions{
    Addrs:     []string{"127.0.0.1:6379"},
    Password: "",
    DB:       0,
  }),
})

UserConfig参数说明:

AppID

  • 类型: string
  • 必传:
  • 示例: ww16143ea0101327cc

小程序、公众号或者企业微信的appId。

MchID

  • 类型: string
  • 必传:
  • 示例: 1611854986

微信支付商户号ID

MchApiV3Key

  • 类型: string
  • 必传:
  • 示例: 1611854986

微信商户里面设置的API V3密钥。参考官方文档: API v3密钥

Key

  • 类型: string
  • 必传:
  • 示例: 管理员设置的随机数

微信商户里面设置的API V2密钥。参考官方文档: 配置API key

CertPath

  • 类型: string
  • 必传:
  • 示例: /.../apiclient_cert.pem

微信商户里面设置的API V3证书。参考官方文档: 私钥和证书

KeyPath

  • 类型: string
  • 必传:
  • 示例: /.../apiclient_key.pem

商户API V3私钥。

SerialNo

  • 类型: string
  • 必传:
  • 示例: 2655A2CD634B06C2A86B28780228A997D047B01A

商户号API V3证书的序列号。 获取证书调用方法:

bash
openssl x509 -noout -serial -in /.../apiclient_cert.pem

正常的情况下会输出:

> serial=2655A2CD634B06C2A86B28780228A997D047B01A

CertificateKeyPath

  • 类型: string
  • 必传:
  • 示例: /.../wx_rsa_public_key.pem

微信支付API使用微信支付 的平台公钥(不是商户私钥 )进行应答签名。 获取请详见官方文档

WechatPaySerial

  • 类型: string
  • 必传:
  • 示例: 5157F09EFDC096DE15EBE81A47057A7232F1B8E1

获取请详见,获取微信支付V3平台证书接口时,微信会一并返回
官方文档

RSAPublicKeyPath

  • 类型: string
  • 必传:
  • 示例: /.../wx_rsa_public_key.pem

微信支付API使用微信支付 的平台公钥(不是商户私钥 )进行应答签名。 获取请详见官方文档

SubAppID

  • 类型: string
  • 必传:
  • 示例: ww16143ea0101327cc

在服务商平台下的,子小程序、公众号或者企业微信的appId。

SubMchID

  • 类型: string
  • 必传:
  • 示例: 1611854986

在服务商平台下的,子微信支付商户号ID。

注意,如果没有在服务商平台下,请不要设置这两个参数。

NotifyURL

  • 类型: string
  • 必传:
  • 示例: https://pay.artisan-cloud.cn/wx/notify

微信支付完成后的通知回调地址。参考官方文档: 支付通知API

Log

  • 类型: payment.Log
  • 必传:
  • 示例:
go
payment.Log{
  Level: "debug",  // 输出日志等级
  File:  "./wechat.log", //  输出日志文件
  Stdout: false, //  是否打印在终端
}

输出日志到指定文件。

Http

  • 类型: payment.Http
  • 必传:
  • 示例:
go
payment.Http{
  Timeout: 30.0,
  BaseURI: "https://api.mch.weixin.qq.com",
}

设置微信支付地址,比如想要设置成沙盒地址,把里面的值改成https://api.mch.weixin.qq.com/sandboxnew就可以啦。

HttpDebug

  • 类型: bool
  • 必传:
  • 默认值:false

是否开启打印SDK调用微信API接口时候的日志,开启之后会显示出提交的参数和微信详情的数据,对于排查问题时候非常有帮助。

Cache

  • 类型: CacheInterface
  • 必传:
  • 默认值:nil

如果需要实现Token中控,例如多个应用实例共享或者和其他应用共享Token。

更多详细内容请参考: Cache配置

Released under the MIT license