【9.1】Golang后端开发系列--Gin快速入门指南

文章目录

    • 一、引言 🌟
    • 二、Gin 框架概述 📖
      • (一)什么是 Gin
      • (二)为什么选择 Gin
    • 三、安装 Gin 框架 📦
      • (一)安装 Go 语言环境
      • (二)使用 Go Modules 安装 Gin
    • 四、路由基础 🌐
      • (一)基本路由定义
      • (二)路由参数
      • (三)查询参数
    • 五、请求处理和响应 📨
      • (一)处理 JSON 数据
      • (二)处理表单数据
    • 六、中间件的使用 🛡️
      • (一)内置中间件
      • (二)中间件的执行顺序
    • 七、模板渲染 🎨
      • (一)使用 HTML 模板
      • (二)模板语法和数据传递
    • 八、错误处理 ❌
      • (一)自定义错误处理
      • (二)全局错误处理
    • 九、文件上传和下载 📁
      • (一)文件上传

一、引言 🌟

在当今的后端开发领域,Go 语言凭借其高效、简洁和强大的并发特性备受开发者青睐。而 Gin 框架更是 Go 语言中构建 Web 服务的利器,它以轻量级和高性能著称,让开发者能够快速搭建功能强大的后端服务。使用 Gin 框架,就像拥有了一把神奇的魔法棒,能将我们的开发效率提升到一个新的高度,轻松应对各种复杂的 Web 应用需求。让我们开启 Gin 后端开发的奇妙之旅吧 🌈

二、Gin 框架概述 📖

(一)什么是 Gin

Gin 是一个用 Go 语言编写的 HTTP Web 框架,它提供了类似于 Martini 框架的 API,但性能更优。Gin 采用了高效的路由和中间件机制,允许开发者快速构建 RESTful API 和 Web 服务。它的语法简洁明了,能够极大地简化 Web 开发流程,减少样板代码,让我们把更多的精力集中在业务逻辑上。可以将 Gin 看作是一个超级高效的桥梁,连接客户端和服务器端,为我们的 Web 应用提供强大的支撑。用 🚀 图标来代表 Gin 框架的高效性。

(二)为什么选择 Gin

  • 性能卓越:Gin 基于 HTTPRouter 构建,具有高性能的路由匹配功能,在处理大量并发请求时表现出色。它使用了高效的路由树算法,能够快速找到对应的处理函数,就像闪电一样快。
  • 中间件支持:Gin 提供了强大的中间件支持,方便我们在请求处理的不同阶段添加自定义逻辑,如日志记录、认证、授权等。中间件就像是一个个功能插件,可以灵活地插拔到请求处理的流程中,增强了程序的可扩展性和可维护性。可以用 🛠️ 图标表示中间件的工具属性。
  • 简洁易用:Gin 的 API 设计简洁直观,容易上手,对于新手来说非常友好。其代码结构清晰,使得开发过程更加流畅,能够让我们快速构建出功能完善的 Web 服务。

三、安装 Gin 框架 📦

(一)安装 Go 语言环境

首先,确保你已经安装了 Go 语言环境。你可以从 Go 官方网站 下载并安装最新版本的 Go。安装完成后,可以通过以下命令检查 Go 版本:

go version

(二)使用 Go Modules 安装 Gin

在 Go 1.11 及以上版本中,推荐使用 Go Modules 来管理依赖。创建一个新的 Go 项目,并初始化 Go Modules:

mkdir gin-example
cd gin-example
go mod init example.com/gin-example

然后,使用以下命令安装 Gin 框架:

go get -u github.com/gin-gonic/gin

这个命令会将 Gin 及其依赖添加到你的项目中。可以使用 go.mod 文件查看项目的依赖情况。

以下是一个简单的代码示例,用于检查 Gin 是否安装成功:

package mainimport ("github.com/gin-gonic/gin"
)func main() {// 创建一个默认的 Gin 引擎r := gin.Default()// 启动服务,监听在 8080 端口r.Run(":8080")
}

在上述代码中:

  • gin.Default() 创建了一个默认的 Gin 引擎,这个引擎包含了一些常用的中间件,如日志记录和恢复机制。
  • r.Run(":8080") 启动了一个 HTTP 服务器,监听在 8080 端口。

运行代码:

go run main.go

如果一切正常,你会看到服务器启动的日志信息,并且可以在浏览器中访问 http://localhost:8080,虽然此时它只会返回 404 错误,因为我们还没有定义路由。

四、路由基础 🌐

(一)基本路由定义

路由是将 HTTP 请求映射到相应处理函数的机制。在 Gin 中,我们可以轻松定义路由。以下是一些基本路由的示例:

package mainimport ("github.com/gin-gonic/gin""net/http"
)func main() {r := gin.Default()// GET 请求路由r.GET("/hello", func(c *gin.Context) {c.String(http.StatusOK, "Hello, Gin!")})// POST 请求路由r.POST("/create", func(c *gin.Context) {c.String(http.StatusCreated, "Created")})// 启动服务,监听在 8080 端口r.Run(":8080")
}

在这个示例中:

  • r.GET("/hello", func(c *gin.Context) {...}) 定义了一个处理 GET 请求的路由,当访问 /hello 路径时,会调用相应的处理函数。
  • c.String(http.StatusOK, "Hello, Gin!") 使用 gin.ContextString 方法发送一个带有状态码和响应内容的响应。
  • 类似地,r.POST("/create", func(c *gin.Context) {...}) 定义了一个处理 POST 请求的路由。

(二)路由参数

我们可以在路由中定义参数,以便从 URL 中获取动态信息。以下是一个示例:

package mainimport ("github.com/gin-gonic/gin""net/http"
)func main() {r := gin.Default()// 定义带参数的路由r.GET("/user/:id", func(c *gin.Context) {id := c.Param("id")c.String(http.StatusOK, "User ID: %s", id)})r.Run(":8080")
}

在这个代码中:

  • r.GET("/user/:id", func(c *gin.Context) {...}) 中的 :id 是一个路由参数。
  • c.Param("id")gin.Context 中获取 id 参数的值。

(三)查询参数

除了路由参数,我们还可以使用查询参数,就像在 URL 中添加 ?key=value 的部分。以下是一个示例:

package mainimport ("github.com/gin-gonic/gin""net/http"
)func main() {r := gin.Default()r.GET("/search", func(c *gin.Context) {query := c.Query("q")c.String(http.StatusOK, "Search query: %s", query)})r.Run(":8080")
}

在这个示例中:

  • c.Query("q") 从查询参数中获取 q 的值。

五、请求处理和响应 📨

(一)处理 JSON 数据

在实际开发中,处理 JSON 数据是很常见的。以下是如何接收和发送 JSON 数据的示例:

package mainimport ("github.com/gin-gonic/gin""net/http"
)type User struct {Name  string `json:"name"`Age   int    `json:"age"`Email string `json:"email"`
}func main() {r := gin.Default()// 发送 JSON 数据r.GET("/user", func(c *gin.Context) {user := User{Name:  "Alice",Age:   25,Email: "alice@example.com",}c.JSON(http.StatusOK, user)})// 接收 JSON 数据r.POST("/user", func(c *gin.Context) {var newUser Userif err := c.ShouldBindJSON(&newUser); err == nil {c.JSON(http.StatusCreated, gin.H{"message": "User created","user":    newUser,})} else {c.JSON(http.StatusBadRequest, gin.H{"error": err.Error(),})}})r.Run(":8080")
}

在这个示例中:

  • c.JSON(http.StatusOK, user) 发送一个 JSON 格式的响应。
  • c.ShouldBindJSON(&newUser) 从请求中解析 JSON 数据到 User 结构体中。

(二)处理表单数据

处理表单数据也是常见的需求,以下是一个示例:

package mainimport ("github.com/gin-gonic/gin""net/http"
)func main() {r := gin.Default()r.POST("/form", func(c *gin.Context) {username := c.PostForm("username")password := c.PostForm("password")c.String(http.StatusOK, "Username: %s, Password: %s", username, password)})r.Run(":8080")
}

在这个代码中:

  • c.PostForm("username")c.PostForm("password") 分别从表单中获取 usernamepassword 的值。

六、中间件的使用 🛡️

(一)内置中间件

Gin 自带了一些内置的中间件,如日志记录和恢复中间件。以下是如何使用自定义中间件的示例:

package mainimport ("github.com/gin-gonic/gin""log""time"
)func Logger() gin.HandlerFunc {return func(c *gin.Context) {start := time.Now()// 处理请求c.Next()// 计算处理时间duration := time.Since(start)log.Printf("Request processed in %v", duration)}
}func main() {r := gin.Default()// 使用自定义中间件r.Use(Logger())r.GET("/middleware", func(c *gin.Context) {c.String(200, "This is a middleware example")})r.Run(":8080")
}

在这个示例中:

  • Logger 是一个自定义中间件函数,它在请求处理前后记录时间并计算处理时长。
  • r.Use(Logger()) 将自定义中间件添加到路由组中。

(二)中间件的执行顺序

中间件的执行顺序非常重要。以下是一个示例,展示多个中间件的执行顺序:

package mainimport ("github.com/gin-gonic/gin""log""time"
)func FirstMiddleware() gin.HandlerFunc {return func(c *gin.Context) {log.Println("First middleware: before")c.Next()log.Println("First middleware: after")}
}func SecondMiddleware() gin.HandlerFunc {return func(c *gin.Context) {log.Println("Second middleware: before")c.Next()log.Println("Second middleware: after")}
}func main() {r := gin.Default()r.Use(FirstMiddleware())r.Use(SecondMiddleware())r.GET("/middleware-order", func(c *gin.Context) {c.String(200, "Middleware order example")})r.Run(":8080")
}

在这个示例中:

  • 当请求 /middleware-order 时,你会看到中间件的执行顺序是按照添加顺序进行的,同时 c.Next() 控制着请求继续向下传递。

七、模板渲染 🎨

(一)使用 HTML 模板

Gin 支持 HTML 模板渲染,以下是一个简单的示例:

package mainimport ("github.com/gin-gonic/gin""net/http"
)func main() {r := gin.Default()// 加载模板文件r.LoadHTMLGlob("templates/*.html")r.GET("/html", func(c *gin.Context) {c.HTML(http.StatusOK, "index.html", gin.H{"title": "Gin HTML Template",})})r.Run(":8080")
}

在这个示例中:

  • r.LoadHTMLGlob("templates/*.html") 加载 templates 目录下的所有 HTML 模板文件。
  • c.HTML(http.StatusOK, "index.html", gin.H{"title": "Gin HTML Template"}) 渲染 index.html 模板并传递数据。

你需要在 templates 目录下创建一个 index.html 文件,例如:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>{{.title }}</title>
</head>
<body><h1>{{.title }}</h1><p>Welcome to Gin HTML Template!</p>
</body>
</html>

(二)模板语法和数据传递

在 HTML 模板中,可以使用 Go 的模板语法传递和显示数据。以下是一个更复杂的示例:

package mainimport ("github.com/gin-gonic/gin""net/http"
)func main() {r := gin.Default()// 加载模板文件r.LoadHTMLGlob("templates/*.html")r.GET("/user", func(c *gin.Context) {users := []string{"Alice", "Bob", "Charlie"}c.HTML(http.StatusOK, "user.html", gin.H{"users": users,})})r.Run(":8080")
}

templates 目录下的 user.html 文件可以这样写:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>User List</title>
</head>
<body><h1>User List</h1><ul>{{ range.users }}<li>{{. }}</li>{{ end }}</ul>
</body>
</html>

在这个示例中:

  • {{ range.users }}...{{ end }} 是 Go 的模板语法,用于遍历 users 切片并生成列表项。

八、错误处理 ❌

(一)自定义错误处理

我们可以在 Gin 中自定义错误处理,以下是一个示例:

package mainimport ("github.com/gin-gonic/gin""net/http"
)func main() {r := gin.Default()// 自定义 404 错误处理r.NoRoute(func(c *gin.Context) {c.JSON(http.StatusNotFound, gin.H{"error": "Page not found",})})// 自定义 500 错误处理r.NoError(func(c *gin.Context, err interface{}) {c.JSON(http.StatusInternalServerError, gin.H{"error": "Internal server error",})})r.Run(":8080")
}

在这个示例中:

  • r.NoRoute(func(c *gin.Context) {...}) 自定义了 404 错误的处理逻辑。
  • r.NoError(func(c *gin.Context, err interface{}) {...}) 自定义了 500 错误的处理逻辑。

(二)全局错误处理

我们也可以设置全局的错误处理中间件,以下是一个示例:

package mainimport ("github.com/gin-gonic/gin""log""net/http"
)func ErrorHandler() gin.HandlerFunc {return func(c *gin.Context) {defer func() {if err := recover(); err!= nil {log.Printf("Error occurred: %v", err)c.JSON(http.StatusInternalServerError, gin.H{"error": "Internal server error",})}}()c.Next()}
}func main() {r := gin.Default()// 添加全局错误处理中间件r.Use(ErrorHandler())r.GET("/error", func(c *gin.Context) {// 模拟一个错误panic("Something went wrong")})r.Run(":8080")
}

在这个示例中:

  • ErrorHandler 中间件使用 recover 来捕获 panic,并将其转换为一个错误响应。

九、文件上传和下载 📁

(一)文件上传

以下是一个文件上传的示例:

package mainimport ("github.com/gin-gonic/gin""net/http"
)func main() {r := gin.Default()r.POST("/upload", func(c *gin.Context) {file, err := c.FormFile("file")if err!= nil {c.JSON(http.StatusBadRequest, gin.H{"error": err.Error()})return}// 保存文件c.SaveUploadedFile(file, "./uploads/"+file.Filename)c.JSON(http.StatusOK, gin.H{"message": "File uploaded successfully"})})r.Run(":8080")
}

在这个示例中:

  • c.FormFile("file") 从请求中获取上传的文件。
  • c.SaveUploadedFile(file, "./uploads/"+file.Filename) 将文件保存到 uploads 目录

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/892671.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Vue 学习之旅:核心技术学习总结与实战案例分享(vue指令下+计算属性+侦听器)

Vue 学习之旅&#xff1a;核心技术学习总结与实战案例分享 文章目录 Vue 学习之旅&#xff1a;核心技术学习总结与实战案例分享一、指令补充&#xff08;一&#xff09;指令修饰符&#xff08;二&#xff09;v-bind 对样式操作的增强&#xff08;三&#xff09;v-model 应用于其…

UE5 打包项目

UE5 打包项目 flyfish 通过 “文件”->“打开项目”&#xff0c;然后在弹出的对话框中选择项目文件&#xff08;通常是以.uproject为后缀的文件&#xff09; 选择目标平台&#xff1a; 在 UE5 主界面中&#xff0c;找到 “平台”&#xff08;Platforms&#xff09;。根据…

1. Doris分布式环境搭建

一. 环境准备 本次测试集群采用3台机器hadoop1、hadoop2、hadoop3, Frontend和Backend部署在同一台机器上&#xff0c;Frontend部署3台组成高可用&#xff0c;Backend部署3个节点&#xff0c;组成3副本存储。 主机IP操作系统FrontendBackendhadoop1192.168.47.128Centos7Foll…

win10电脑 定时关机

win10电脑 定时关机 https://weibo.com/ttarticle/p/show?id2309405110707766296723 二、使用任务计划程序设置定时关机打开任务计划程序&#xff1a; 按下“Win S”组合键&#xff0c;打开搜索框。 在搜索框中输入“任务计划程序”&#xff0c;然后点击搜索结果中的“任务…

day07_Spark SQL

文章目录 day07_Spark SQL课程笔记一、今日课程内容二、Spark SQL函数定义&#xff08;掌握&#xff09;1、窗口函数2、自定义函数背景2.1 回顾函数分类标准:SQL最开始是_内置函数&自定义函数_两种 2.2 自定义函数背景 3、Spark原生自定义UDF函数3.1 自定义函数流程&#x…

Hadoop3.x 万字解析,从入门到剖析源码

&#x1f496; 欢迎来到我的博客&#xff01; 非常高兴能在这里与您相遇。在这里&#xff0c;您不仅能获得有趣的技术分享&#xff0c;还能感受到轻松愉快的氛围。无论您是编程新手&#xff0c;还是资深开发者&#xff0c;都能在这里找到属于您的知识宝藏&#xff0c;学习和成长…

Java 实现 Elasticsearch 查询当前索引全部数据

Java 实现 Elasticsearch 查询当前索引全部数据 需求背景通常情况Java 实现查询 Elasticsearch 全部数据写在最后 需求背景 通常情况下&#xff0c;Elasticsearch 为了提高查询效率&#xff0c;对于不指定分页查询条数的查询语句&#xff0c;默认会返回10条数据。那么这就会有…

Elasticsearch ES|QL 地理空间索引加入纽约犯罪地图

可以根据地理空间数据连接两个索引。在本教程中&#xff0c;我将向你展示如何通过混合邻里多边形和 GPS 犯罪事件坐标来创建纽约市的犯罪地图。 安装 如果你还没有安装好自己的 Elasticsearch 及 Kibana 的话&#xff0c;请参考如下的链接来进行安装。 如何在 Linux&#xff0…

C#学习笔记 --- 简单应用

1.operator 运算符重载&#xff1a;使自定义类可以当做操作数一样进行使用。规则自己定。 2.partial 分部类&#xff1a; 同名方法写在不同位置&#xff0c;可以当成一个类使用。 3.索引器&#xff1a;使自定义类可以像数组一样通过索引值 访问到对应的数据。 4.params 数…

【Flink】Flink内存管理

Flink内存整体结构图&#xff1a; JobManager内存管理 JVM 进程总内存(Total Process Memory)Flink总内存(Total Flink Memory)&#xff1a;JVM进程总内存减去JVM Metaspace(元空间)和JVM Overhead(运行时开销)上图解释&#xff1a; JVM进程总内存为2G;JVM运行时开销(JVM Overh…

MYSQL8创建新用户报错:You have an error in your SQL syntax;check...

本文所用——MYSQL版本&#xff1a;8.0.25 baidu都是直接创建新用户并赋权&#xff0c;如下&#xff1a; GRANT ALL PRIVILEGES ON *.* TO 用户名% IDENTIFIED BY 密码 WITH GRANT OPTION;但是我用的MYSQL版本它就不行&#xff0c;会报错&#xff01; 经查阅资料发现——MY…

力扣经典练习题之198.打家劫舍

今天继续给大家分享一道力扣的做题心得今天这道题目是198.打家劫舍,这是一道非常经典的问题,在动态规划中经常考到这类问题,题目如下: 题目链接:198.打家劫舍 1,题目分析 首先此题就是给我们了一个数组,代表可以偷的房屋中的对应的金额,我们是一个小偷,一次可以偷很多…

万物互联的背后:MCU嵌入式硬件的奇幻之旅

文章背景&#xff1a;嵌入式硬件是什么&#xff1f; 你可能听说过嵌入式硬件&#xff0c;却总觉得它像是实验室里神秘的玩意儿。其实&#xff0c;它就在我们身边——从你手上的智能手表到车里的倒车雷达&#xff0c;无一不是嵌入式硬件的“杰作”。想象一块小小的电路板&#x…

LabVIEW数据库管理系统

LabVIEW数据库管理系统&#xff08;DBMS&#xff09;是一种集成了数据库技术与数据采集、控制系统的解决方案。通过LabVIEW的强大图形化编程环境&#xff0c;结合数据库的高效数据存储与管理能力&#xff0c;开发人员可以实现高效的数据交互、存储、查询、更新和报告生成。LabV…

如何在 Linux、MacOS 以及 Windows 中打开控制面板

控制面板不仅仅是一系列图标和菜单的集合&#xff1b;它是通往优化个人计算体验的大门。通过它&#xff0c;用户可以轻松调整从外观到性能的各种参数&#xff0c;确保他们的电脑能够完美地适应自己的需求。无论是想要提升系统安全性、管理硬件设备&#xff0c;还是简单地改变桌…

python 轮廓 获取环形区域

目录 效果图&#xff1a; 代码&#xff1a; 效果图&#xff1a; 代码&#xff1a; import cv2 import numpy as np# 读取图像 image cv2.imread(rE:\project\jijia\tools_jijia\img_tools\ground_mask.jpg, cv2.IMREAD_GRAYSCALE) # 二值化图像 # 二值化图像 _, binary cv…

Clickhouse基础(一)

数据存储的目录&#xff0c;在存储数据时是先经过压缩后再存储的&#xff0c;压缩效率很高 操作命令&#xff1a; sudo clickhouse start sudo clickhouse restart sudo clickhouse status进入clickhouse clickhouse-client -mCREATE TABLE db_13.t_assist (modelId UInt64,…

基于spingbott+html+Thymeleaf的24小时智能服务器监控平台设计与实现

博主介绍&#xff1a;硕士研究生&#xff0c;专注于信息化技术领域开发与管理&#xff0c;会使用java、标准c/c等开发语言&#xff0c;以及毕业项目实战✌ 从事基于java BS架构、CS架构、c/c 编程工作近16年&#xff0c;拥有近12年的管理工作经验&#xff0c;拥有较丰富的技术架…

从 SQL 语句到数据库操作

1. SQL 语句分类 数据定义语言 DDL &#xff1a; 用于定义或修改数据库中的结构&#xff0c;如&#xff1a;创建、修改、删除数据库对象。create、drop alter 数据操作语言 DML &#xff1a; 用于添加、删除、更新数据库中的数据。select、insert alter、drop 数据控制语言 D…

Excel中SUM求和为0?难道是Excel有Bug!

大家好&#xff0c;我是小鱼。 在日常工作中有时会遇到这样的情况&#xff0c;对Excel表格数据进行求和时&#xff0c;结果竟然是0&#xff0c;很多小伙伴甚至都怀疑是不是Excel有Bug&#xff01;其实&#xff0c;在WPS的Excel表格中数据求和&#xff0c;结果为0无法正确求和的…