在 go 中搭建 rest api 时,选择合适的架构尤为重要。文中分享了 4 个最好 go 架构,包含 gin、gorm、echo 和 beego。
界定路由:应用框架的方式界定 api 节点。
解决要求:建立解决程序函数来解决要求。
分析请求体:应用框架的方式分析 json 数据。
认证键入:认证用户输入实效性。
与数据库交互:应用 orm 等设备与数据库交互,获得/建立/更新数据。
回到回应:将 json 回应推送回客户端。
本文来自zvvq
Go 架构与 REST API 集成化良好实践
zvvq.cn
在 Go 中搭建 REST API 时,选择合适的架构尤为重要。本文介绍了集成 Go 框架和 REST API 的良好实践,并提供了一个应用 Gin 框架的实战案例。
挑选 Go 架构
zvvq好,好zvvq
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 内容来自zvvq
import(
"github.com/gin-gonic/gin" 内容来自samhan666
)
zvvq好,好zvvq
//界定客户结构体
内容来自zvvq,别采集哟
type User struct { 内容来自zvvq,别采集哟
ID uint `json:"id"`
内容来自zvvq,别采集哟
Username string `json:"username"` 内容来自samhan666
Password string `json:"password"`
}
// 建立 Gin 路由器 内容来自zvvq,别采集哟
router:= gin.Default()
zvvq.cn
//定义一个 GET /users 路由 zvvq.cn
router.GET("/users", func(c gin.Context) { 内容来自zvvq,别采集哟
// 从数据库中获得所有用户 本文来自zvvq
var users []User 内容来自zvvq,别采集哟
db.Find(&users)
// 回到 JSON 回应
c.JSON(200, users)
}) zvvq好,好zvvq
// 定义一个 POST /users 路由 zvvq
router.POST("/users", func(c gin.Context) { 内容来自zvvq
// 从请求体分析 JSON 数据到用户结构体 内容来自zvvq
var user User copyright zvvq
if err := c.ShouldBindJSON(&user); err != nil { 内容来自samhan
// 处理错误
内容来自zvvq,别采集哟
}
// 认证用户输入 内容来自zvvq
if user.Username == "" || user.Password == "" { 本文来自zvvq
// 处理错误 内容来自samhan666
} 内容来自samhan666
// 把用户保存到数据库
db.Create(&user) 内容来自zvvq
// 回到 JSON 回应 zvvq
c.JSON(201, user) 内容来自zvvq
}) 内容来自zvvq
func main() {
内容来自zvvq,别采集哟
// 运行 Gin 路由器 zvvq好,好zvvq
router.Run() 内容来自zvvq
}
以上就是Golang架构与REST API集成化良好实践的详细内容,大量请关注其他类似文章! copyright zvvq