news 2026/7/1 17:55:31

Gin笔记一之项目建立与运行

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Gin笔记一之项目建立与运行

本系列笔记预计通过四到五篇笔记内容介绍 Gin 框架的核心内容,然后通过一个简单的示例介绍一个 Gin 项目的目录结构,然后介绍如何将一个 Gin 项目使用 Docker 打包部署。

此外,还将介绍在 Gin 项目里连接使用 Redis、Mongo、MySQL 等操作。

以下是本篇笔记内容:

模块安装

项目运行

接口返回参数

运行模式

1、模块安装

创建一个文件夹 gin_proj,然后进入该文件夹执行 go mod init gin_proj 初始化 Go 模块。

然后安装 gin 模块:

go get github.com/gin-gonic/gin

2、项目运行

我们在 gin_proj 文件夹下创建一个 main.go 文件,然后定义一个接口,然后返回数据的代码如下:

package main

import (

"net/http"

"github.com/gin-gonic/gin"

)

func main() {

r := gin.Default()

r.GET("/test", func(c *gin.Context) {

c.JSON(http.StatusOK, gin.H{"code": 0, "message": "success"})

})

r.Run(":9898")

}

然后在浏览器中或者使用 postman 访问 http://localhost:9898/test 就可以看到对应的结果输出。

其代码释义如下。

1. gin.Default()

gin.Default() 返回的类型是 *gin.Engine,我们可以用其定义路由和分组,设置 HTTP 请求类型,比如这里的 r.GET() 以及后面将要介绍的路由组。

2. r.GET()

r.GET() 用于设置请求的方式,比如这里是 GET 请求,如果是 post 请求可以使用 r.POST()。

GET() 方法接收两个参数,第一个参数是路由,比如这里是 /test,第二个参数是个可变参数,...HandlerFunc,可接收多个 HandlerFunc 类型,此类型是一个函数,接收 *gin.Context 参数,其定义如下:

type HandlerFunc func(*Context)

这里的第二个参数,除了路由的处理函数,我们还可以在其中加上中间件处理。

在上面的代码示例中,第二个参数用的是匿名函数,我们还可以直接将这个函数提出去:

func TestHandler(c *gin.Context) {

c.JSON(http.StatusOK, gin.H{"code": 0, "message": "success"})

}

func main() {

r := gin.Default()

r.GET("/test", TestHandler)

r.Run(":9898")

}

3. r.Run()

r.Run() 接收运行时使用的端口,这里传入的是 :9898,表示运行在 9898 端口。

如果不传入参数,默认使用 8080 端口。

Run() 还返回一个 err 参数,表示运行时 error:

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

if err != nil {

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

}

3、接口返回参数

在上面 TestHandler 函数中,接收的参数是 *gin.Context,我们可以使用其处理请求流程,获取请求数据,处理响应,上下文数据传递等,这个在后面做具体的介绍。

这里返回的代码如下:

c.JSON(http.StatusOK, gin.H{"code": 0, "message": "success"})

1. c.JSON()

c.JSON() 这里返回的是 /test 接口的内容,接收两个参数,第一个是状态码,也就是 HTTP 状态码,比如 200、404 这种。

第二个参数的类型是 any,接收任意类型的数据,我们这里返回的是 gin.H{},这个在后面再介绍。

这里的 c.JSON() 是用于向客户端返回 json 格式的数据,会将第二个参数序列化后返回。

除了 c.JSON() 外,我们还可以使用 c.String() 返回纯文本,c.HTML() 返回 HTML 页面,和其他的 c.File() 返回文件等操作。

2. http.StatusOK

http.StatusOK 是 net/http 模块下表示 HTTP 状态码的常量,其值为 200,在 c.JSON(),我们也可以直接使用 200 作为返回值。

c.JSON(200, gin.H{"code": 0, "message": "success"})

除了 http.StatusOK,还有其他 2xx,3xx,4xx,5xx 等状态码在该模块下都有定义,这里就不赘述了。

3. gin.H{}

gin.H 类型是一个 map,其定义如下:

type H map[string]any

除了像上面一个对返回的字段挨个进行赋值,我们还可以直接返回一个 struct 类型。

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)

}

4、运行模式

gin 里一共定义了三种模式,分别是 debug、release、test,其定义如下:

const (

// DebugMode indicates gin mode is debug.

DebugMode = "debug"

// ReleaseMode indicates gin mode is release.

ReleaseMode = "release"

// TestMode indicates gin mode is test.

TestMode = "test"

)

系统默认运行模式是 debug 模式,当我们直接运行 go run main.go 时,其输出信息如下:

[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

会输出当前的运行模式,可以访问的接口等信息,这里第一行的输出还介绍了我们使用的 r := gin.Default() 会默认使用 Logger and Recovery 两个中间件,这个后面在介绍 gin.Engine 的再详细介绍。

而如果我们设置运行模式为 release 模式,控制台仅仅会在访问接口的时候输出一条访问信息,包括访问时间、耗时、请求方式和访问的接口名称:

[GIN] 2025/08/19 - 00:32:09 | 200 | 140.916µs | ::1 | GET "/test"

设置运行模式

我们可以通过下面的方法获取和设置运行模式:

// 获取运行模式

gin.Mode()

// 设置运行模式

gin.SetMode(gin.ReleaseMode)

gin 在运行时,会先加载系统环境变量 GIN_MODE,然后根据获取的值将系统设置为对应的模式。

所以我们在部署系统时,如果是以 Docker 形式部署,可以设置此变量来设置对应的运行模式。

declare -x GIN_MODE="release"

也可以在 main.go 中直接设置:

gin.SetMode(gin.ReleaseMode)

以上就是本篇笔记全部内容,主要介绍了 gin 框架的运行方式,并介绍了一个简单示例如何设置接口并返回,还有 gin 的系统模式设置,接下来几篇笔记将详细介绍 gin.Engine 与路由的相关操作,gin.Context 与响应处理,中间件等设置。

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

【python大数据毕设实战】哮喘患者症状数据可视化分析系统、Hadoop、计算机毕业设计、包括数据爬取、数据分析、数据可视化、机器学习

🍊作者:计算机毕设匠心工作室 🍊简介:毕业后就一直专业从事计算机软件程序开发,至今也有8年工作经验。擅长Java、Python、微信小程序、安卓、大数据、PHP、.NET|C#、Golang等。 擅长:按照需求定制化开发项目…

作者头像 李华
网站建设 2026/7/1 8:23:26

9 个降AI率工具,MBA 必备避坑指南

9 个降AI率工具,MBA 必备避坑指南 AI降重工具:MBA论文的智能护航 MBA论文写作过程中,越来越多的学生开始依赖AI工具进行内容生成。然而,随着高校对AIGC率的严格管控,如何在保持论文原创性和学术规范的同时,…

作者头像 李华
网站建设 2026/6/24 22:45:25

Windows系统文件inetmib1.dll丢失损坏 下载修复方法

在使用电脑系统时经常会出现丢失找不到某些文件的情况,由于很多常用软件都是采用 Microsoft Visual Studio 编写的,所以这类软件的运行需要依赖微软Visual C运行库,比如像 QQ、迅雷、Adobe 软件等等,如果没有安装VC运行库或者安装…

作者头像 李华
网站建设 2026/7/1 2:36:23

Boost电路的右半平面零点

3.1、为什么存在这个右零点?(关键点:先储能再释放)答:右零点不是数学上的巧合,而是由Boost电路独特的能量传输方式决定的。其物理过程可以这样理解:假设电路已经稳定工作,此时我们突…

作者头像 李华
网站建设 2026/6/30 15:01:41

【全球AI伦理治理】

AI伦理治理框架的全球协同案例 欧盟《人工智能法案》提出基于风险分级的四层治理体系,禁止社会评分等高风险应用。OECD的AI政策观察站已收录全球700余项政策倡议,形成跨国数据库共享机制。新加坡的Model AI Governance Framework为亚洲企业提供可认证的伦…

作者头像 李华
网站建设 2026/7/1 10:57:01

毕业季必看!7款免费AI写论文神器实测,一站式搞定选题、大纲到降重

如果你是正在熬夜赶Deadline的毕业生,或是面临着科研压力、被导师催稿的研究生,又或是没钱又要写高质量论文的大学生,那么这篇文章简直就是为你量身打造的!在学术的道路上,我们都曾经历过论文选题的迷茫、写作过程的煎…

作者头像 李华