在 go 中搭建 rest api 时,选择合适的架构尤为重要。文中分享了 4 个最好 go 架构,包含 gin、gorm、echo 和 beego。
界定路由:应用框架的方式界定 api 节点。
解决要求:建立解决程序函数来解决要求。
分析请求体:应用框架的方式分析 json 数据。
认证键入:认证用户输入实效性。
与数据库交互:应用 orm 等设备与数据库交互,获得/建立/更新数据。
回到回应:将 json 回应推送回客户端。 内容来自samhan
copyright zvvq
Go 架构与 REST API 集成化良好实践
内容来自zvvq,别采集哟
在 Go 中搭建 REST API 时,选择合适的架构尤为重要。本文介绍了集成 Go 框架和 REST API 的良好实践,并提供了一个应用 Gin 框架的实战案例。 内容来自zvvq
挑选 Go 架构
内容来自samhan
Gin:轻量、高性能架构,适用搭建中小型 API。 GORM:用以与 SQL 数据库交互的 ORM(对象关系映射器)。 Echo:另一个受人欢迎轻量架构,给予丰富的功能和扩展性。 Beego:应用 Go 内置的 net/http 库搭建的框架,给予简单 API开发感受。
集成REST API
界定路由:应用 Router.GET("/api/users") 和 Router.POST("/api/users") 等路由方式界定 API节点。
解决要求:建立解决程序函数来解决从客户端接收的要求。
分析请求体:应用 c.ShouldBindJSON(&user) 分析来自请求体的 JSON 数据。
认证键入:应用 validator 包或自定认证逻辑认证用户输入。
与数据库交互:应用 GORM 或其它 ORM与数据库交互,获得/建立/更新数据。
回到回应:应用 c.JSON(200, user) 将 JSON 回应推送回客户端。
实战案例:应用 Gin 搭建简易REST API 内容来自zvvq
packagemain copyright zvvq
import( 内容来自samhan
"github.com/gin-gonic/gin" zvvq
) zvvq.cn
//界定客户结构体
type User struct {
ID uint `json:"id"`
zvvq
Username string `json:"username"` copyright zvvq
Password string `json:"password"`
} 内容来自zvvq
// 建立 Gin 路由器 本文来自zvvq
router:= gin.Default() zvvq
//定义一个 GET /users 路由
router.GET("/users", func(c *gin.Context) { 内容来自samhan666
// 从数据库中获得所有用户 内容来自samhan
var users []User
db.Find(&users) zvvq.cn
// 回到 JSON 回应
zvvq.cn
c.JSON(200, users)
}) 本文来自zvvq
// 定义一个 POST /users 路由 内容来自zvvq,别采集哟
router.POST("/users", func(c *gin.Context) {
// 从请求体分析 JSON 数据到用户结构体
zvvq
var user User
if err := c.ShouldBindJSON(&user); err != nil { copyright zvvq
// 处理错误 内容来自samhan
}
// 认证用户输入
内容来自samhan666
if user.Username == "" || user.Password == "" {
// 处理错误 zvvq.cn
} zvvq
// 把用户保存到数据库
db.Create(&user) 本文来自zvvq
// 回到 JSON 回应
本文来自zvvq
c.JSON(201, user)
内容来自zvvq,别采集哟
}) zvvq好,好zvvq
func main() { zvvq
// 运行 Gin 路由器
zvvq.cn
router.Run()
}
以上就是Golang架构与REST API集成化良好实践的详细内容,大量请关注其他类似文章!