欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 房产 > 建筑 > 支付宝API-SKD-GO版

支付宝API-SKD-GO版

2025/5/13 13:50:15 来源:https://blog.csdn.net/weixin_39682289/article/details/147904219  浏览:    关键词:支付宝API-SKD-GO版

前言

支付宝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 mainimport ("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.NotifyResponseerr := alipayRoute.Open.Pay.VerifyNotify(request.VerifyNotifyRequest{Params: "", // 回调参数}, &notifyResp)if err != nil {panic("验签失败!")}// 预授权转支付var fundAuthDetail response.AlipayFundAuthOperationDetailQueryResponsereqData, 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.goapi路由文件

项目扩展

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

添加支付接口示例

支付宝支付接口

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

请求参数

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

package requestimport "encoding/json"type AlipayTradePayRequest struct {NotifyUrl  stringBizContent 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"`     // 用户支付宝uidSellerId    string                 `json:"seller_id,omitempty"`    // 卖家支付宝uidSubMerchant 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 alipayimport ("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 alipaytype Route struct {Open *OpenRoute
}type OpenRoute struct {Pay    *OpenPayRouter
}func NewRoute(client Client) *Route {return &Route{Open: &OpenRoute{Pay:    NewOpenPayRouter(client),},}
}	

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

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词