实施GO后端的付款API不仅对于刚开始使用的杜松子酒框架开发人员,而且对于使用框架已经使用了一段时间的开发人员而言。
。本文将显示如何简单地集成条纹结帐REST API,该API将产生指向Stripe Checkout屏幕的链接,以供您的用户在应用程序中执行付款。
使用此命令第一个安装条纹软件包
go get -u github.com/stripe/stripe-go/v74
现在添加此控制器
func CreateCheckoutUrl(c *gin.Context) {
var body struct {
Amount int64 `form:"amount"`
ReceiptEmail string `form:"email"`
Metadata string `form:"metadata"`
}
if err := c.Bind(&body); err != nil {
c.JSON(http.StatusBadRequest, gin.H{
"error": "Failed to read body",
})
return
}
apiKey := os.Getenv("STRIPE_SECRET_KEY")
stripe.Key = apiKey
domain := "https://your.domain.com/"
params := &stripe.CheckoutSessionParams{
LineItems: []*stripe.CheckoutSessionLineItemParams{
{
PriceData: &stripe.CheckoutSessionLineItemPriceDataParams{
Currency: stripe.String("usd"),
ProductData: &stripe.CheckoutSessionLineItemPriceDataProductDataParams{
Name: stripe. String("Product Name Here"),
},
TaxBehavior: stripe.String("exclusive"),
UnitAmount: stripe.Int64(body.Amount * 100),
},
Quantity: stripe.Int64(1),
},
},
CustomerEmail: &body.ReceiptEmail,
Mode: stripe.String(string(stripe.CheckoutSessionModePayment)),
SuccessURL: stripe.String(domain + "/"),
CancelURL: stripe.String(domain + "/"),
AutomaticTax: &stripe.CheckoutSessionAutomaticTaxParams{Enabled: stripe.Bool(true)},
}
params.AddMetadata("id", body.Metadata)
fmt.Println("params - ", params)
s, err := session.New(params)
if err != nil {
log.Printf("Error creating session: %v", err)
c.JSON(http.StatusInternalServerError, gin.H{
"error": err.Error(),
})
return
}
c.JSON(http.StatusOK, gin.H{
"checkout_url": s.URL,
})
}
在您的路线中添加以下端点
// stripe api
r.POST("/create-checkout-url/", controllers.CreateCheckoutUrl)
完成了,您现在可以通过向我们刚刚创建的端点提出帖子请求来部署杜松子酒后端并测试API。