【9.2】Golang后端开发系列--Gin路由定义与实战使用

文章目录

      • 一、Gin 框架路由的基本定义方式
        • 1. 简单路由创建
        • 2. 路由参数
        • 3. 查询参数
      • 二、商业大项目中的路由定义和服务调用
        • 1. 路由模块化
        • 2. 路由组和中间件
        • 3. 中间件的使用
        • 4. 服务层调用
        • 5. 错误处理
        • 6. 版本控制
        • 7. 路由注册

一、Gin 框架路由的基本定义方式

1. 简单路由创建

使用 gin.Default() 创建一个带有默认中间件的路由引擎,然后通过 GET, POST, PUT, DELETE 等方法来定义不同 HTTP 方法的路由。

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, World!")})// 启动服务r.Run(":8080")
}
2. 路由参数

使用 : 来定义路由参数,通过 c.Param() 方法从请求中提取参数。

r.GET("/users/:userID", func(c *gin.Context) {userID := c.Param("userID")c.String(http.StatusOK, "User ID: %s", userID)
})
3. 查询参数

使用 c.Query() 方法来获取查询参数。

r.GET("/search", func(c *gin.Context) {query := c.Query("q")c.String(http.StatusOK, "Search query: %s", query)
})

二、商业大项目中的路由定义和服务调用

1. 路由模块化

为了使代码结构更清晰和易于维护,将路由定义分散到不同的文件和包中。

routes/user.go

package routesimport ("github.com/gin-gonic/gin""yourproject/services"
)func SetupUserRoutes(r *gin.RouterGroup) {r.GET("/", services.GetAllUsers)r.GET("/:id", services.GetUserByID)r.POST("/", services.CreateUser)r.PUT("/:id", services.UpdateUser)r.DELETE("/:id", services.DeleteUser)
}

services/user.go

package servicesimport ("github.com/gin-gonic/gin""net/http"
)func GetAllUsers(c *gin.Context) {// 调用数据访问层或其他服务层的函数来获取用户列表users, err := userService.GetAll()if err!= nil {c.JSON(http.StatusInternalServerError, gin.H{"error": "Failed to fetch users"})return}c.JSON(http.StatusOK, users)
}func GetUserByID(c *gin.Context) {id := c.Param("id")user, err := userService.GetByID(id)if err!= nil {c.JSON(http.StatusNotFound, gin.H{"error": "User not found"})return}c.JSON(http.StatusOK, user)
}func CreateUser(c *gin.Context) {var newUser Userif err := c.BindJSON(&newUser); err!= nil {c.JSON(http.StatusBadRequest, gin.H{"error": "Invalid input"})return}if err := userService.Create(newUser); err!= nil {c.JSON(http.StatusInternalServerError, gin.H{"error": "Failed to create user"})return}c.JSON(http.StatusCreated, gin.H{"message": "User created successfully"})
}func UpdateUser(c *gin.Context) {id := c.Param("id")var updatedUser Userif err := c.BindJSON(&updatedUser); err!= nil {c.JSON(http.StatusBadRequest, gin.H{"error": "Invalid input"})return}if err := userService.Update(id, updatedUser); err!= nil {c.JSON(http.StatusInternalServerError, gin.H{"error": "Failed to update user"})return}c.JSON(http.StatusOK, gin.H{"message": "User updated successfully"})
}func DeleteUser(c *gin.Context) {id := c.Param("id")if err := userService.Delete(id); err!= nil {c.JSON(http.StatusInternalServerError, gin.H{"error": "Failed to delete user"})return}c.JSON(http.StatusOK, gin.H{"message": "User deleted successfully"})
}
2. 路由组和中间件

使用路由组来组织相关的路由,并且可以为路由组添加中间件。

routes/router.go

package routesimport ("github.com/gin-gonic/gin""yourproject/middleware""yourproject/services"
)func SetupRoutes() *gin.Engine {r := gin.Default()// 公共中间件,例如日志、认证等r.Use(middleware.Logger(), middleware.Authenticate())// 用户路由组users := r.Group("/users")SetupUserRoutes(users)// 产品路由组products := r.Group("/products")SetupProductRoutes(products)return r
}
3. 中间件的使用

中间件可以在请求处理的不同阶段执行逻辑,如日志记录、认证、授权、错误处理等。

middleware/logger.go

package middlewareimport ("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("%s %s %s %v", c.Request.Method, c.Request.URL.Path, c.Writer.Status(), duration)}
}

middleware/authenticate.go

package middlewareimport ("github.com/gin-gonic/gin""net/http"
)func Authenticate() gin.HandlerFunc {return func(c *gin.Context) {// 检查用户是否认证,例如通过 token 验证if!isAuthenticated(c) {c.AbortWithStatusJSON(http.StatusUnauthorized, gin.H{"error": "Unauthorized"})return}c.Next()}
}func isAuthenticated(c *gin.Context) bool {// 实际的认证逻辑,例如检查请求头中的 tokenauthHeader := c.GetHeader("Authorization")if authHeader == "" {return false}// 更复杂的验证逻辑,如验证 token 的有效性return true
}
4. 服务层调用

将业务逻辑封装在服务层,路由处理函数负责调用相应的服务。

services/user_service.go

package servicesimport ("errors"
)type UserService struct{}func (s *UserService) GetAll() ([]User, error) {// 模拟从数据库或其他数据源获取用户列表// 这里应该调用实际的数据访问层函数users := []User{{ID: "1", Name: "Alice"},{ID: "2", Name: "Bob"},}return users, nil
}func (s *UserService) GetByID(id string) (*User, error) {// 模拟根据 ID 获取用户// 这里应该调用实际的数据访问层函数if id == "1" {return &User{ID: "1", Name: "Alice"}, nil}return nil, errors.New("User not found")
}func (s *UserService) Create(user User) error {// 模拟创建用户// 这里应该调用实际的数据访问层函数return nil
}func (s *UserService) Update(id string, user User) error {// 模拟更新用户// 这里应该调用实际的数据访问层函数return nil
}func (s *UserService) Delete(id string) error {// 模拟删除用户// 这里应该调用实际的数据访问层函数return nil
}
5. 错误处理

在路由处理函数和服务层中都要进行错误处理,确保将错误信息正确返回给客户端。

func GetUserByID(c *gin.Context) {id := c.Param("id")user, err := userService.GetByID(id)if err!= nil {c.JSON(http.StatusNotFound, gin.H{"error": err.Error()})return}c.JSON(http.StatusOK, user)
}
6. 版本控制

对于 API 的不同版本,可以使用路由组进行管理。

func SetupRoutes() *gin.Engine {r := gin.Default()v1 := r.Group("/v1")SetupV1Routes(v1)v2 := r.Group("/v2")SetupV2Routes(v2)return r
}
7. 路由注册

main 函数中注册路由并启动服务。

package mainimport ("yourproject/routes"
)func main() {r := routes.SetupRoutes()r.Run(":8080")
}

通过上述方式,在商业大项目中使用 Gin 框架时,可以将路由定义、中间件、服务调用和错误处理等部分分离,实现清晰的分层架构,提高代码的可维护性和可扩展性。这样做有助于团队协作开发,并且方便对不同功能模块进行单独测试和优化。同时,合理使用路由组和中间件可以确保不同路由的逻辑隔离和功能复用。

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

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

相关文章

STM32 FreeRTOS移植

目录 FreeRTOS源码结构介绍 获取源码 1、 官网下载 2、 Github下载 源码结构介绍 源码整体结构 FreeRTOS文件夹结构 Source文件夹结构如下 portable文件夹结构 RVDS文件夹 MemMang文件夹 FreeRTOS在基于寄存器项目中移植步骤 目录添加源码文件 工程添加源码文件 …

【ASP.NET学习】Web Forms创建Web应用

文章目录 什么是 Web Forms?ASP.NET Web Forms - HTML 页面用 ASP.NET 编写的 Hello RUNOOB.COM它是如何工作的?经典 ASP ASP.NET Web Forms - 服务器控件经典 ASP 的局限性ASP.NET - 服务器控件ASP.NET - HTML 服务器控件ASP.NET - Web 服务器控件ASP.N…

Linux 常见运营维护,从安装软件开始,到mysql,php,redis,tomcat等软件安装,配置,优化,持续更新中。。。

下载centos7 CentOS 7 完整版(DVD): https://mirrors.aliyun.com/centos/7/isos/x86_64/CentOS-7-x86_64-DVD-2009.isoCentOS 7 最小化版(Minimal): https://mirrors.aliyun.com/centos/7/isos/x86_64/C…

用户界面软件05

已知应用 几乎所有的流行的用户界面架构都使用这种模式。我在这里举三个例子: 1. Seeheim 用户界面架构的特点是有一个应用核心的领域层和一个用户界面层。后者 被分为两层,叫做表示层和对话控制层。因为这个架构和面向事务系统有渊源,没有…

从玩具到工业控制--51单片机的跨界传奇【2】

咱们在上一篇博客里面讲解了什么是单片机《单片机入门》,让大家对单片机有了初步的了解。我们今天继续讲解一些有关单片机的知识,顺便也讲解一下我们单片机用到的C语言知识。如果你对C语言还不太了解的话,可以看看博主的C语言专栏哟&#xff…

LVGL移植高通点阵字库GT30L24A3W

字库芯片: GT30L24A3W MCU:STM32F429 LVGL版本:V8.4 一、实现gt_read_data() 和 r_dat_bat() 请参考下面视频 如何在32位MCU上使用高通点阵字库_哔哩哔哩_bilibili 高通字库使用教程(1)硬件链接与注意事项部分_哔哩哔哩_bilibili 高通字库使用教程(2)SPI底层函数使用_哔哩…

C# OpenCV机器视觉:转速测量

在一个看似平常却又暗藏神秘能量的日子里,阿杰正在他那充满科技感的实验室里,对着一堆奇奇怪怪的仪器发呆。突然,手机铃声如一道凌厉的剑气划破寂静,原来是工厂的赵厂长打来的紧急电话:“阿杰啊,咱们工厂新…

【Vue】Vue组件--上

目录 一、组件基础 二、组件的嵌套关系 1. 基础架构 2. 嵌套 三、组件注册方式 1. 局部注册: 2. 全局注册: 四、组件传递数据 1. 基础架构 2. 传递多值 3. 动态传递数据 五、组件传递多种数据类型 1. Number 2. Array 3. Object 六、组…

unity下载newtonsoft-json

Package Manager,输入com.unity.nuget.newtonsoft-json 右键Assets-Reinport All

SpringBoot项目实战(40)--Beetl网页开发在控制层使用通用方法映射前端不同路径的网页

在SpringBoot中使用Beetl做前端页面,后端如何使用Controller映射前端不同的页面,不需要为每个前端页面单独增加控制层方法? 因为前端页面比较多,每个前端页面对应一个独立Controller方法也是不现实的,总不能每增加一个…

【自动化测试】—— Appium安装配置保姆教程(图文详解)

目录 一. 环境准备 二. JDK安装 1. 下载JDK 2. 安装JDK 3. 配置环境 4. 验证安装 三. Android SDK安装 1. 下载Android SDK 2. 安装Android SDK 3. 安装工具 4. 配置环境 5. 验证安装 四. NodeJS安装 1. 下载NodeJS 2. 安装NodeJS 3. 验证安装 4. 安装淘宝镜像…

Oracle 终止正在执行的SQL

目录 一. 背景二. 操作简介三. 投入数据四. 效果展示 一. 背景 项目中要求进行性能测试,需要向指定的表中投入几百万条数据。 在数据投入的过程中发现投入的数据不对,需要紧急停止SQL的执行。 二. 操作简介 👉需要DBA权限👈 ⏹…

【SH】Xiaomi9刷Windows10系统研发记录 、手机刷Windows系统教程、小米9重装win10系统

文章目录 参考资料云盘资料软硬件环境手机解锁刷机驱动绑定账号和设备解锁手机 Mindows工具箱安装工具箱和修复下载下载安卓和woa资源包第三方Recovery 一键安装Windows准备工作创建分区安装系统 效果展示Windows和Android一键互换Win切换安卓安卓切换Win 删除分区 参考资料 解…

MWORKS 2025a 直播回顾 | 第二期:M语言计算环境重磅更新

MWORKS.Syslab首次推出时已实现基于Julia语言的科学计算环境,尽管如此,仍有大量工程师团队坚持使用M语言相关软件。除了使用习惯和学习语言等问题,更深层的原因在于大量历史代码资产复用的问题。为了解决这一关键问题,同元软控在后…

晨辉面试抽签和评分管理系统之八:随机编排考生的面试批次(以教师资格考试面试为例)

晨辉面试抽签和评分管理系统(下载地址:www.chenhuisoft.cn)是公务员招录面试、教师资格考试面试、企业招录面试等各类面试通用的考生编排、考生入场抽签、候考室倒计时管理、面试考官抽签、面试评分记录和成绩核算的面试全流程信息化管理软件。提供了考生…

专用小软件,完全免费,非常丝滑

今天给大家介绍一个专门将PDF数电发票合并打印的软件,这个软件可以批量操作,完全免费没有任何的广告。 电子发票专用批量打印工具 免费批量使用 软件无需安装,解压之后双击这个图标就能直接使用了。 点击右上角的加号,选中需要打…

《leetcode-runner》如何手搓一个debug调试器——架构

本文主要聚焦leetcode-runner对于debug功能的整体设计,并讲述设计原因以及存在的难点 设计引入 让我们来思考一下,一个最简单的调试器需要哪些内容 首先,它能够接受用户的输入 其次,它能够读懂用户想让调试器干嘛,…

【0x005B】HCI_Write_Default_Erroneous_Data_Reporting命令详解

目录 一、命令概述 二、命令格式及参数 2.1. HCI_Write_Default_Erroneous_Data_Reporting命令格式 2.2. Erroneous_Data_Reporting 三、生成事件及参数 3.1. HCI_Command_Complete事件 3.2. 状态码(Status) 四、命令执行流程 4.1. 命令发起阶段(主机端) 4.2. 命…

uniapp 小程序 textarea 层级穿透,聚焦光标位置错误怎么办?

前言 在开发微信小程序时,使用 textarea 组件可能会遇到一些棘手的问题。最近我在使用 uniapp 开发微信小程序时,就遇到了两个非常令人头疼的问题: 层级穿透:由于 textarea 是原生组件,任何元素都无法遮盖住它。当其…

Kotlin 快速上手指南:从安装 IntelliJ IDEA 到编写第一个程序

文章目录 什么是kotlinIntelliJ IDEA安装 IntelliJ IDEA创建 Kotlin 项目运行 Kotlin 程序更改进入后默认打开上一次项目的设置打开 IntelliJ IDEA进入设置:重新启动 IntelliJ IDEA:快速学习Kotlin变量声明类型推断条件表达式定义函数单表达式函数when 表达式when 语句的基本…