支付宝API-SKD-GO版

发布于:2025-05-13 ⋅ 阅读:(16) ⋅ 点赞:(0)

前言

支付宝api的sdk没有提供go版,这里自己封装了一个go版的sdk,有需要的朋友可以自取使用

支付宝 AliPay SDK for Go, 集成简单,功能完善,持续更新,支持公钥证书和普通公钥进行签名和验签。

Github地址

GitHub - abc-kaka/alipay: 支付宝 AliPay SDK for Go, 集成简单,功能完善,持续更新,支持公钥证书和普通公钥进行签名和验签,支持文件上传和接口内容加密。

安装

go get github.com/abc-kaka/alipay

使用demo

package main

import (
	"fmt"
	"github.com/abc-kaka/alipay/open/pay/request"
	"github.com/abc-kaka/alipay/open/pay/response"
	"github.com/abc-kaka/alipay"
)

func main() {
	// 支付宝应用私钥示例
	privateKey := "-----BEGIN RSA PRIVATE KEY-----
MIIEpAIBAAKCAQEA2KqF5piuUQMQyT0GH0SOBZ+4StulRRpnhnIn8O+LoToEXAMPLE
MwTxkzm1cwlwGvWJk0HrOM19m1Xe5B9Z5EOYAfMK9Z5c0FxH1+c4XrLKvAxvOgIM
2+gU3wLLCZWaPPXf1gPoC5a8YcUxX0d9RC0hXSmVtYBEXAMPLEq+yPuM7QIDAQAB
AoIBAQCJt9K3Oehms+sCZB4xzgx5sH4G5E0jKNqaZ5CJItvGu2OfEXAMPLEBDjk2E
...
-----END RSA PRIVATE KEY-----"
	// 支付宝应用公钥示例
	publicKey := "-----BEGIN PUBLIC KEY-----
MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEArfI9kA/3L1jEXAMPLEUsnA
Do0QTr9k8Y9I3Ym3n8+0ZsXKwNus2Re6nlXDPK3Hpg7n4kDzGGP1opFltlyEXAMPLE
...
-----END PUBLIC KEY-----"
	// 支付宝公钥示例
	alipayPublicKey := "-----BEGIN PUBLIC KEY-----
MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAw+EdmJjzpU9fEXAMPLEeXL
vGJdY6vdcSTzCB3aAcEXAMPLEPU+6o2NxYlEu/fFJK2LyoXrNmB7MEBQIDAQAB
-----END PUBLIC KEY-----"

	// 获取配置
	config := alipay.NewConfig()
	config.AppId = "201407230000xxxx"    // 应用app_id示例
	config.AppAuthToken = ""    // 授权令牌,非必填,按接口需要
	config.PrivateKey = privateKey   // 应用私钥
	config.PublicKey = publicKey // 应用公钥
	config.AlipayPublicKey = alipayPublicKey // 支付宝公钥,非必填,按接口需要
	// 客户端
	client := alipay.NewClient(config)
	// 支付宝路由,支付宝api通过这个路由调用
	alipayRoute := alipay.NewRoute(client)

	// 支付回调验签、返回回调参数
	var notifyResp response.NotifyResponse
	err := alipayRoute.Open.Pay.VerifyNotify(request.VerifyNotifyRequest{
		Params: "", // 回调参数
	}, &notifyResp)
	if err != nil {
		panic("验签失败!")
	}

	// 预授权转支付
	var fundAuthDetail response.AlipayFundAuthOperationDetailQueryResponse
	reqData, err := alipayRoute.Open.Pay.AlipayFundAuthOperationDetailQuery(request.AlipayFundAuthOperationDetailQueryRequest{
		OutRequestNo: cast.ToString(v2OrderDepositMinus.OutTradeNo),
		OutOrderNo:   cast.ToString(v2OrderDepositMinus.OutTradeNo),
	}, &fundAuthDetail)
	if err != nil {
		panic("预授权转支付失败!")
	}
	fmt.Println("请求参数、结果", reqData)
}

项目目录结构说明

目录 说明
common 通用工具目录
mini 小程序api的请求参数、请求结果结构体
open 开放api的请求参数、请求结果结构体,包含人员、支付
client.go 客户端
config.go 配置
route.go api路由文件

项目扩展

可以看到目前的接口并不全,我这边只同步了部分接口,但扩展其实也很简单,只需要去支付宝官网把api接口的请求参数、请求结果copy到本项目,再添加对应的路由即可。

添加支付接口示例

支付宝支付接口

小程序文档 - 支付宝文档中心

请求参数

创建请求参数文件:open/pay/request/alipay_trade_pay_request.go

package request

import "encoding/json"

type AlipayTradePayRequest struct {
	NotifyUrl  string
	BizContent AlipayTradePayBizContent
}

// 普通预授权冻结押金转支付接口说明:https://opendocs.alipay.com/open/02cdx8?scene=34&pathHash=dd2813f3
type AlipayTradePayBizContent struct {
	OutTradeNo      string                 `json:"out_trade_no,omitempty"`
	TotalAmount     float64                `json:"total_amount,omitempty"`
	Subject         string                 `json:"subject,omitempty"`
	ProductCode     string                 `json:"product_code,omitempty"`
	AuthNo          string                 `json:"auth_no,omitempty"`
	AuthConfirmMode string                 `json:"auth_confirm_mode,omitempty"`
	ExtendParams    map[string]interface{} `json:"extend_params,omitempty"`
	BusinessParams  map[string]interface{} `json:"business_params,omitempty"`

	// 直付通参数
	BuyerId     string                 `json:"buyer_id,omitempty"`     // 用户支付宝uid
	SellerId    string                 `json:"seller_id,omitempty"`    // 卖家支付宝uid
	SubMerchant map[string]interface{} `json:"sub_merchant,omitempty"` // 二级商户信息
	SettleInfo  map[string]interface{} `json:"settle_info,omitempty"`  // 结算详细信息
}

// ToMap 转map
func (r *AlipayTradePayRequest) ToMap(v any) map[string]string {
	bizContent, _ := json.Marshal(r.BizContent)
	return map[string]string{
		"notify_url":  r.NotifyUrl,
		"biz_content": string(bizContent),
	}
}

请求结果

创建文件:open/pay/response/alipay_trade_create_response.go

package response

// AlipayTradeCreateResponse (统一收单交易创建接口)-响应
type AlipayTradeCreateResponse struct {
	Code       string `json:"code"`
	Msg        string `json:"msg"`
	OutTradeNo string `json:"out_trade_no,omitempty"`
	TradeNo    string `json:"trade_no,omitempty"`
}

添加api接口

文件:router_open_pay.go

package alipay

import (
	"github.com/abc-kaka/alipay/open/pay/request"
	"github.com/abc-kaka/alipay/open/pay/response"
)

// OpenPayRouter H5&移动APP - 支付产品 - 路由
type OpenPayRouter struct {
	client Client
}

// NewOpenPayRouter 创建H5&移动APP - 支付产品 - 路由
func NewOpenPayRouter(client Client) *OpenPayRouter {
	return &OpenPayRouter{client: client}
}

// AlipayTradeCreate 统一收单交易创建接口
// https://opendocs.alipay.com/mini/6039ed0c_alipay.trade.create?pathHash=779dc517&ref=api&scene=de4d6a1e0c6e423b9eefa7c3a6dcb7a5
func (r *OpenPayRouter) AlipayTradeCreate(request request.AlipayTradeCreateRequest, response *response.AlipayTradeCreateResponse) (reqData map[string]interface{}, err error) {
	reqData, err = r.client.Exec("alipay.trade.create", &request, response)
	return
}

绑定到路由上

文件:route.go

package alipay

type Route struct {
	Open *OpenRoute
}

type OpenRoute struct {
	Pay    *OpenPayRouter
}

func NewRoute(client Client) *Route {
	return &Route{
		Open: &OpenRoute{
			Pay:    NewOpenPayRouter(client),
		},
	}
}	

恭喜你,完成接口的添加!


网站公告

今日签到

点亮在社区的每一天
去签到