news 2026/6/12 21:34:15

Gin笔记二之gin.Engine和路由设置

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Gin笔记二之gin.Engine和路由设置

这一篇笔记主要介绍 gin.Engine,设置路由等操作,以下是本篇笔记目录:

gin.Default() 和 gin.New()

HTTP 方法

路由分组与中间件

1、gin.Default() 和 gin.New()

前面第一篇笔记介绍,创建一个 gin 的路由引擎使用的函数是 gin.Default(),返回的类型是 *gin.Engine,我们可以使用其创建路由和路由组。

除了这个函数外,还有一个 gin.New(),其返回的也是 *gin.Engine,但是不一样的是 gin.Default() 会对 gin.Engine 添加默认的 Logger() 和 Recovery() 中间件。

这两个函数大致内容如下:

func New(opts ...OptionFunc) *Engine {

...

}

func Default(opts ...OptionFunc) *Engine {

...

engine := New()

engine.Use(Logger(), Recovery())

...

}

我们使用第一篇笔记中使用 debug 模式运行系统后输出的信息可以再看一下:

[GIN-debug] [WARNING] Creating an Engine instance with the Logger and Recovery middleware already attached.

[GIN-debug] [WARNING] Running in "debug" mode. Switch to "release" mode in production.

- using env: export GIN_MODE=release

- using code: gin.SetMode(gin.ReleaseMode)

[GIN-debug] GET /test --> main.main.func1 (3 handlers)

[GIN-debug] [WARNING] You trusted all proxies, this is NOT safe. We recommend you to set a value.

Please check https://pkg.go.dev/github.com/gin-gonic/gin#readme-don-t-trust-all-proxies for details.

[GIN-debug] Listening and serving HTTP on :9898

我们使用的是 gin.Default() 运行的系统,所以在第一行告诉我们创建了一个带有 Logger and Recovery 中间件的 Engine。

同时第三行输出路由信息的地方,标明了这个路由指向的处理函数,后面的括号里是 3 handlers,这个意思是除了我们处理路由的 handler,还有两个默认的中间件 handler,也就是这里的 Logger() 和 Recovery() 中间件。

下面介绍一下 Logger() 和 Recovery() 这两个 handler 的作用。

1. Logger()

默认的 Logger() 会输出接口调用的信息,比如第一篇中我们定义了一个 /test 接口,当我们调用这个接口的时候,控制台会输出下面这条信息:

[GIN] 2025/08/19 - 23:15:26 | 200 | 36.666µs | 127.0.0.1 | GET "/test"

可以看到日志中会包含请求时间、返回的 HTTP 状态码、请求耗时、调用方 ip、请求方式和接口名称等。

这条日志信息的输出就是 Logger() 这个中间件起的作用。

在其内部,会调用一个 LoggerWithConfig() 函数,获取到请求的 ip、记录调用时间、调用方式等信息,然后进行输出,下面是部分源码信息:

param.TimeStamp = time.Now()

param.Latency = param.TimeStamp.Sub(start)

param.ClientIP = c.ClientIP()

param.Method = c.Request.Method

param.StatusCode = c.Writer.Status()

param.ErrorMessage = c.Errors.ByType(ErrorTypePrivate).String()

2. Recovery()

Recovery() 中间件则可以为我们捕获程序中未处理的 panic,记录错误信息并返回 500 状态码信息,比如我们在第一篇笔记中使用的 TestHandler 函数,我们在其中加一个除数为 0 的错误:

func TestHandler(c *gin.Context) {

response := TestResponse{

Code: 0,

Message: "success",

}

a := 0

fmt.Println(1 / a)

c.JSON(http.StatusOK, response)

}

在接口调用的时候,如果我们使用的是 gin.Default(),那么客户端不会报错,而是会收到一个 HTTP 状态码为 500 的报错信息,而如果使用的是 gin.New(),客户端则会直接发生错误。

总的来说,Logger() 和 Recovery() 这两个的中间件是 gin 框架为我们默认添加的对于开发者来说较为友好的两个操作,在后面介绍中间件的时候,我们也可以手动实现这两个功能。

2、HTTP 方法

gin.Engine 支持配置 HTTP 多个方法,比如 GET、POST、PUT、DELETE 等。

以第一篇笔记中的代码为例,其设置方法如下:

r.GET("/test", TestHandler)

r.POST("/test", TestHandler)

r.PUT("/test", TestHandler)

r.DELETE("/test", TestHandler)

3、路由分组与中间件

除了设置单个路由,我们还可以对路由进行分组设置,比如需要控制版本,或者模块设置需要统一的前缀,又或者是需要统一设置中间件功能的时候。

其整体代码示例如下:

package main

import (

"fmt"

"net/http"

"github.com/gin-gonic/gin"

)

type TestResponse struct {

Code int `json:"code"`

Message string `json:"message"`

}

func TestHandler(c *gin.Context) {

response := TestResponse{

Code: 0,

Message: "success",

}

c.JSON(http.StatusOK, response)

}

func main() {

r := gin.Default()

v1 := r.Group("/v1")

{

v1.GET("/test", TestHandler)

}

err := r.Run(":9898")

if err != nil {

fmt.Println("gin run in 9898 error:", err)

}

}

这里,我们设置了一个路由名称以 v1 为前缀的路由组,其下每个路由的访问都需要带有 /v1,这样就实现了统一设置路由前缀的功能。

而如果我们需要向其中添加中间件的时候,也可以不用挨个路由进行设置,而是在 v1 路由组的设置中就可以实现,比如:

v1 := r.Group("/v1", Middleware1, Middleware2)

这样,其下每个路由的 handler 函数在调用前就都会先调用 Middleware1 和 Middleware2 这两个中间件。

以上就是本篇笔记关于 gin.Engine 的全部内容,其实中间件的相关操作也应该属于 gin.Engine 的内容,但是那部分需要介绍的知识点和想要用于介绍的代码示例略多,所以就单独开一篇笔记在后面再介绍。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 16:13:32

3个V-JEPA实战案例:如何用自监督学习解决视频分析难题

3个V-JEPA实战案例:如何用自监督学习解决视频分析难题 【免费下载链接】jepa 项目地址: https://gitcode.com/GitHub_Trending/je/jepa V-JEPA作为Meta AI推出的自监督视频表征学习框架,正在改变传统视频分析的范式。无需大量标注数据&#xff0…

作者头像 李华
网站建设 2026/6/12 2:03:50

ConvNeXt模型部署指南:5分钟快速搭建现代卷积网络

ConvNeXt模型部署指南:5分钟快速搭建现代卷积网络 【免费下载链接】ConvNeXt Code release for ConvNeXt model 项目地址: https://gitcode.com/gh_mirrors/co/ConvNeXt ConvNeXt是一种完全基于标准卷积模块构建的纯卷积网络模型,在图像识别和深度…

作者头像 李华
网站建设 2026/6/10 7:23:29

专业钢琴采样库:88键高品质WAV音频资源完整指南

专业钢琴采样库:88键高品质WAV音频资源完整指南 【免费下载链接】钢琴88键独立音频文件 本仓库提供了一个名为“钢琴88键独立音频文件.zip”的资源文件,该文件包含了钢琴全部88个音阶的音频文件。每个音阶的录音都被单独保存为一个文件,音频格…

作者头像 李华
网站建设 2026/6/12 1:00:05

还在盲猜理想型?AI 让情感探索更清晰

在情感探索的过程中,很多人都曾陷入 “不知道自己想要什么” 的迷茫:对理想伴侣的想象模糊笼统,缺乏具体认知;凭感觉寻找却屡屡碰壁,浪费时间与精力;难以清晰表达自身情感需求,影响亲密关系建立…

作者头像 李华
网站建设 2026/6/12 1:57:22

视频配音还在重拍?AI 声画同步让影像表达更灵活

在视频内容创作中,“声画匹配” 是影响观感的核心因素,但传统模式长期面临效率低、效果硬的痛点:录制后发现配音失误需重新拍摄,多语言适配要反复调整口型,后期剪辑需逐帧对齐语音与画面,耗时耗力且易出现违…

作者头像 李华
网站建设 2026/6/12 13:54:23

GitCode口袋工具开发学习

GitCode口袋工具开发学习 https://blog.csdn.net/2301_80035882/article/details/155135274?spm1001.2014.3001.5502以上是我学习的笔记链接 一、前期准备:搭建项目框架 接着,我参照文章的项目架构,在lib目录下搭建了core、pages、widgets三…

作者头像 李华