gin入门教程(6):全局中间件,自定义中间件

在 Gin 中,中间件用于处理请求的预处理和后处理,可以实现日志、身份验证、跨域资源共享(CORS)等功能。下面是如何使用和创建中间件的基本步骤:

1. 使用内置中间件

Gin 提供了一些内置中间件,例如:

  • 日志中间件
go 复制代码
r.Use(gin.Logger())
  • 恢复中间件(处理恐慌并恢复):
go 复制代码
r.Use(gin.Recovery())
2. 自定义中间件

您可以轻松创建自定义中间件,例如简单的身份验证:

go 复制代码
func AuthMiddleware() gin.HandlerFunc {
    return func(c *gin.Context) {
        token := c.GetHeader("Authorization")
        if token != "your_secret_token" {
            c.JSON(401, gin.H{"error": "Unauthorized"})
            c.Abort() // 中止后续处理
            return
        }
        c.Next() // 继续处理请求
    }
}
3. 注册中间件

您可以在路由组中注册中间件,或在全局范围内使用:

  • 全局中间件
go 复制代码
r.Use(AuthMiddleware())
  • 路由组中间件
go 复制代码
v1 := r.Group("/v1")
v1.Use(AuthMiddleware())
{
    v1.GET("/users", getUsers)
}
4. 中间件顺序

中间件的执行顺序是根据它们被注册的顺序,先注册的中间件先执行。在调用 c.Next() 后,后续的中间件会执行,最后返回响应。

示例

以下是一个使用中间件的完整示例:

go 复制代码
package main

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

func main() {
    r := gin.Default()
    
    // 注册日志和恢复中间件
    r.Use(gin.Logger())
    r.Use(gin.Recovery())
    
    // 注册自定义中间件
    r.Use(AuthMiddleware())

    r.GET("/ping", func(c *gin.Context) {
        c.JSON(200, gin.H{"message": "pong"})
    })

    r.Run(":8080")
}

func AuthMiddleware() gin.HandlerFunc {
    return func(c *gin.Context) {
        token := c.GetHeader("Authorization")
        if token != "your_secret_token" {
            c.JSON(401, gin.H{"error": "Unauthorized"})
            c.Abort()
            return
        }
        c.Next()
    }
}

总结

中间件是 Gin 中非常强大的特性,通过它可以在请求处理流程中插入额外的逻辑,以满足不同的需求。您可以根据实际情况自由组合使用。

相关推荐
007php0079 小时前
GoZero 上传文件File到阿里云 OSS 报错及优化方案
服务器·开发语言·数据库·python·阿里云·架构·golang
不爱说话郭德纲11 小时前
聚焦 Go 语言框架,探索创新实践过程
go·编程语言
高 朗11 小时前
【GO基础学习】基础语法(2)切片slice
开发语言·学习·golang·slice
IT书架11 小时前
golang面试题
开发语言·后端·golang
醒过来摸鱼17 小时前
【Golang】协程
开发语言·后端·golang
谷大羽18 小时前
Kafka Stream实战教程
spring boot·后端·中间件·kafka·stream
灼华十一20 小时前
算法编程题-排序
数据结构·算法·golang·排序算法
宋发元20 小时前
Go语言使用 kafka-go 消费 Kafka 消息教程
golang·kafka·linq
宋发元20 小时前
Go消费kafka中kafkaReader.FetchMessage(ctx)和kafkaReader.ReadMessage(ctx)的区别
golang·kafka·linq
隔着天花板看星星1 天前
Kafka-创建topic源码
大数据·分布式·中间件·kafka