Gin框架的分组路由与分组中间件

在Gin框架中,分组路由和分组中间件是实现RESTful API时非常重要的特性。通过分组路由,我们可以将相关的路由组织在一起,提高代码的可读性和可维护性。而分组中间件则允许我们在一个路由组内统一应用一系列的中间件,对请求进行预处理或后处理。

下面,我们将详细介绍Gin的分组路由和分组中间件。

1. 分组路由

Gin的Group方法允许我们创建路由组,可以将一系列具有相同前缀的路由组合在一起。这样做不仅使得路由定义更加清晰,还可以通过为路由组添加中间件来统一处理这些路由的请求。

2. 分组中间件

分组中间件通过Use方法应用到路由组上,这个中间件会在该组内的所有路由处理之前或之后执行。这是处理日志记录、认证、权限校验等常见需求的强大工具。

3. 中间件写法

在Gin中,中间件本质上是一个具有gin.HandlerFunc签名的函数。这里介绍两种常见的中间件写法:

  • 全局中间件 :直接绑定到全局的*gin.Engine实例上。
  • 分组中间件 :通过Group方法创建的路由组调用Use方法添加。
4. 代码示例
go 复制代码
package main

import (
	"fmt"
	"github.com/gin-gonic/gin"
)

type UserInfo struct {
	Name string `json:"name"`
	Age  int    `json:"age"`
}

type ArticleInfo struct {
	Title   string `json:"title"`
	Content string `json:"content"` 
}

type Response struct {
	Code int        `json:"code"`
	Data interface{} `json:"data"` 
	Msg  string     `json:"msg"`
}

func UserListView(c *gin.Context) {
	var userList []UserInfo = []UserInfo{
		{"a", 1},
		{"b", 2},
		{"c", 3},
	}
	c.JSON(200, Response{0, userList, "ok"})
}

func ArticleListView(c *gin.Context) {
	var articleList []ArticleInfo = []ArticleInfo{
		{"go", "article 1 content"},
		{"java", "article 2 content"},
		{"c", "article 3 content"},
	}
	c.JSON(200, Response{0, articleList, "ok"})
}

func getOne(c *gin.Context) {
	c.JSON(200, Response{0, UserInfo{"a", 1}, "ok"})
}

func userHandler() gin.HandlerFunc {
	return func(c *gin.Context) {
		fmt.Println("userHandler...in")
		c.Next()
		fmt.Println("userHandler...out")
	}
}

func articleHandler(c *gin.Context) {
	fmt.Println("articleHandler...in")
	c.Next()
	fmt.Println("articleHandler...out")
}

func main() {
	r := gin.Default()

	// 分组路由和中间件
	apiGroup := r.Group("/api")
	{
		userManage := apiGroup.Group("userManage").Use(userHandler())
		{
			userManage.GET("/users", UserListView)
			userManage.GET("/user/:id", getOne) // 示例:获取单个用户
		}

		articleManage := apiGroup.Group("articleManage").Use(articleHandler)
		{
			articleManage.GET("/articles", ArticleListView)
			// 可以在这里添加更多与文章相关的路由
		}
	}

	r.Run(":8080")
}
相关推荐
PD我是你的真爱粉7 小时前
RabbitMQRPC与死信队列
后端·python·中间件
草根大哥7 小时前
AI编程实践-homex物业管理平台(Go + Vue3 + MySQL 多租户落地)
mysql·golang·vue·ai编程·gin·物业管理系统·多租户
曼岛_2 天前
[Java实战]springboot3项目使用宝蓝德中间件 bes-lite-spring-boot-starter 添加安全头
java·安全·中间件
带娃的IT创业者2 天前
专栏系列04(模块1第4篇) 《蓝图系统与中间件帝国:40+个路由模块的组织哲学》
python·中间件·flask·蓝图·blueprint·python蓝图
金刚猿3 天前
02_虚拟机中间件部署_安装 MySQL 服务【创建用户、数据挂载】
数据库·mysql·中间件
萧曵 丶3 天前
主流消息队列(MQ)的核心架构、底层原理
中间件·架构·mq
爆米花byh4 天前
在RockyLinux9环境的Kafka4.1.1单机版安装(无ZK依赖)
中间件·kafka
爆米花byh4 天前
在RockyLinux9环境的Storm2.8.3单机版安装
linux·中间件·storm
PD我是你的真爱粉4 天前
FastAPI中间件与路由
中间件·fastapi
会算数的⑨4 天前
Kafka知识点问题驱动式的回顾与复习——(一)
分布式·后端·中间件·kafka