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