在 Go 应用中 如何像 FastAPI 一样优雅地构建控制器
文章精选推荐
1 JetBrains Ai assistant 编程工具让你的工作效率翻倍
2 Extra Icons:JetBrains IDE的图标增强神器
3 IDEA插件推荐-SequenceDiagram,自动生成时序图
4 BashSupport Pro 这个ides插件主要是用来干嘛的 ?
5 IDEA必装的插件:Spring Boot Helper的使用与功能特点
6 Ai assistant ,又是一个写代码神器
文章正文
go-rest-kit 是一个基于 Go 语言和 Gin 框架的快速构建 RESTful API 的工具库,它提供了一套方便的工具,使得开发者能够更加高效地构建 API,避免重复编写大量的代码,特别是在处理控制器、路由、请求验证和错误处理等方面。
该库的设计灵感部分来源于 Python 的 FastAPI,并且为 Go 开发者提供了类似的便捷体验。你可以通过更简洁的方式定义控制器、处理请求和响应,而不需要手动编写大量冗余代码。
1. 安装 go-rest-kit
你首先需要安装 go-rest-kit,可以通过 go get 来安装:
go get github.com/goharbor/go-rest-kit
2. 基本的用法
在 go-rest-kit 中,核心功能包括控制器(Controller)、请求和响应的结构体定义、路由注册、验证请求数据等。接下来我将通过一个简单的例子展示如何使用 go-rest-kit 来快速构建一个 RESTful API。
2.1 初始化项目
首先,你需要安装 Gin 和 go-rest-kit:
go get github.com/gin-gonic/gin
go get github.com/goharbor/go-rest-kit
2.2 创建控制器
在 go-rest-kit 中,控制器可以通过定义结构体并用特定标签标注来简化 API 的开发。你可以将这些结构体视为 FastAPI 中的“路径操作函数”。例如,定义一个处理用户的控制器,提供简单的用户信息查询功能。
package controllersimport ("github.com/gin-gonic/gin""github.com/goharbor/go-rest-kit""net/http"
)// UserController 定义了一个用户控制器
type UserController struct {restkit.BaseController
}// GetUser 定义了一个获取用户信息的 API 路由
// 通过结构体标签直接绑定请求参数
func (u *UserController) GetUser(c *gin.Context) {userID := c.Param("user_id")// 假设从数据库或其他地方获取用户信息user := map[string]interface{}{"id": userID,"name": "John Doe","age": 30,}c.JSON(http.StatusOK, user)
}
2.3 注册控制器和路由
通过 go-rest-kit,你可以快速注册控制器并定义路由,避免了手动绑定每个路由的繁琐操作。你只需将控制器实例化并注册到 restkit.Router 中。
package mainimport ("github.com/gin-gonic/gin""github.com/goharbor/go-rest-kit""github.com/yourusername/yourproject/controllers"
)func main() {r := gin.Default()// 初始化 RestKit 路由restKit := restkit.NewRouter(r)// 注册 UserControlleruserController := &controllers.UserController{}restKit.AddController(userController)// 启动服务r.Run(":8080")
}
3. 请求数据验证
go-rest-kit 通过结构体标签的方式简化了请求数据的验证。例如,定义一个请求体结构体并绑定到控制器的函数中,自动进行参数校验和绑定。
package controllersimport ("github.com/gin-gonic/gin""github.com/goharbor/go-rest-kit""net/http""github.com/go-playground/validator/v10"
)type CreateUserRequest struct {Name string `json:"name" binding:"required"`Email string `json:"email" binding:"required,email"`Age int `json:"age" binding:"required,min=18"`
}type UserController struct {restkit.BaseController
}func (u *UserController) CreateUser(c *gin.Context) {var request CreateUserRequest// 自动绑定请求数据并验证if err := c.ShouldBindJSON(&request); err != nil {c.JSON(http.StatusBadRequest, gin.H{"error": err.Error()})return}// 假设数据插入成功c.JSON(http.StatusOK, gin.H{"message": "User created successfully","user": request,})
}
在上面的代码中,CreateUserRequest 结构体使用了 binding 标签来进行参数验证,Go 语言的 validator 库会自动校验字段是否合法。
3.1 请求验证说明
go-rest-kit 的请求验证是基于 go-playground/validator 库的,提供了一些常见的验证功能,如:
required:字段必填email:邮箱格式验证min、max:数字或字符串的最小/最大值验证
你可以根据自己的需求自定义更多的验证规则。
3.2 返回响应
go-rest-kit 还提供了简化的响应处理机制。在上面的 CreateUser 函数中,我们使用了 c.JSON 方法来返回 JSON 格式的响应。
你还可以使用 c.JSON 来返回自定义状态码和数据,或者返回一个错误响应。
4. 错误处理
go-rest-kit 提供了一个统一的错误处理机制。你可以通过继承 BaseController 类来处理所有的错误。
例如:
package controllersimport ("github.com/gin-gonic/gin""github.com/goharbor/go-rest-kit""net/http"
)type UserController struct {restkit.BaseController
}func (u *UserController) GetUser(c *gin.Context) {userID := c.Param("user_id")if userID == "" {u.HandleError(c, http.StatusBadRequest, "User ID is required")return}// 处理逻辑并返回数据c.JSON(http.StatusOK, gin.H{"user_id": userID,"name": "John Doe","email": "johndoe@example.com",})
}
在上面的代码中,HandleError 方法用于统一的错误处理,返回详细的错误信息。
5. 支持自定义中间件
你还可以为 API 添加中间件来处理认证、日志记录等功能。go-rest-kit 提供了内建的支持,允许你通过 AddMiddleware 方法注册自定义的中间件。
例如,添加一个简单的认证中间件:
package mainimport ("github.com/gin-gonic/gin""github.com/goharbor/go-rest-kit""net/http"
)func AuthMiddleware() gin.HandlerFunc {return func(c *gin.Context) {authHeader := c.GetHeader("Authorization")if authHeader != "Bearer my-token" {c.JSON(http.StatusUnauthorized, gin.H{"error": "Unauthorized"})c.Abort()return}c.Next()}
}func main() {r := gin.Default()restKit := restkit.NewRouter(r)// 注册中间件r.Use(AuthMiddleware())// 添加控制器userController := &controllers.UserController{}restKit.AddController(userController)// 启动服务器r.Run(":8080")
}
6. 总结
通过 go-rest-kit,你可以快速构建基于 Gin 的 RESTful API,免去手动处理路由、验证、错误处理等繁琐工作。它为开发者提供了一个简洁、统一的 API 开发模式,通过控制器和结构体的方式快速定义和处理请求,使得代码更加简洁和可维护。
如果你的项目需要频繁处理复杂的请求和响应,go-rest-kit 是一个很好的选择,尤其是在你希望快速构建高效 RESTful API 时。
相关文章:
在 Go 应用中 如何像 FastAPI 一样优雅地构建控制器
文章精选推荐 1 JetBrains Ai assistant 编程工具让你的工作效率翻倍 2 Extra Icons:JetBrains IDE的图标增强神器 3 IDEA插件推荐-SequenceDiagram,自动生成时序图 4 BashSupport Pro 这个ides插件主要是用来干嘛的 ? 5 IDEA必装的插件&…...
用户界面的UML建模11
然而,在用户界面方面,重要的是要了解《boundary》类是如何与这个异常分层结构进行关联的。 《exception》类的对象可以作为《control》类的对象。因此,《exception》类能够聚合《boundary》类。 参见图12,《exception》Database…...
历代iPhone运行内存大小和电池容量信息
系列设备名称充电端口标配充电线PD快充无线充电 (W)标配充电器电池容量 (mAh)发布时间RAM运存iPhone 16iPhone 16 Pro MaxUSB Type-CUSB-C to USB-C支持25无47472024/9/108GB LPDDR5XiPhone 16 ProUSB Type-CUSB-C to USB-C支持25无35772024/9/108GB LPDDR5XiPhone 16 PlusUSB …...
计算机网络之---物理层设备
什么是物理层设备 物理层设备是指负责数据在物理媒介上传输的硬件设备,它们主要处理数据的转换、信号的传输与接收,而不涉及数据的内容或意义。常见的物理层设备包括网卡、集线器、光纤收发器、调制解调器等。 物理层设备有哪些 1、网卡(N…...
57. Three.js案例-创建一个带有聚光灯和旋转立方体的3D场景
57. Three.js案例-创建一个带有聚光灯和旋转立方体的3D场景 实现效果 该案例实现了使用Three.js创建一个带有聚光灯和旋转立方体的3D场景。 知识点 WebGLRenderer(WebGL渲染器) THREE.WebGLRenderer 是 Three.js 中用于将场景渲染为 WebGL 内容的核…...
第八讲 一元函数积分学的概念和性质
不定积分 1.原函数与不定积分 需知道:F(X)可导必连续 2.原函数(不定积分)存在定理 (1)连续函数f(x)必有原函数F(x) (2)含有第一类间断点和无穷间断点的函数f(x)在包含该间断点的区间内必没有原函数F(x). 速记:只有震荡可能有…...
ADMM原理及应用
文章目录 1. ADMM原理1.1. 数学形式1.2. 传统“乘子法”和它的不足1.3. ADMM 的核心思想:分步做1.4. Scaled Form of ADMM1.5. 迭代过程中主要检查的两大残差1.6. 怎么设置停止准则(Stopping Criteria)?1.7. 自适应调整罚参数 ρ \rho ρ(又…...
mysql之sql的优化方案(重点)
1、全字段匹配是最棒的 假如一个Staffs 这个表,将 name,age ,pos 组合成了一个联合索引,在where条件下,能够使用到的索引越多越好。 EXPLAIN SELECT * FROM staffs WHERE NAME July; EXPLAIN SELECT * FROM staffs WHERE NAME July AND age…...
【LeetCode】303. 区域和检索 - 数组不可变
目录 描述Python1. 前缀和 描述 给定一个整数数组nums,处理以下类型的多个查询:计算索引left和right(包含left和right)之间的nums元素的 和 ,其中left < right 实现NumArray类: NumArray(int[] nums)&a…...
前端开发 vue 中如何实现 u-form 多个form表单同时校验
在 Vue 项目中使用 UView UI 的 u-form 组件时,多个表单同时校验的需求非常常见。例如,当我们有多个表单需要在同一个页面中进行校验并提交时,我们需要确保每个表单都能进行单独验证,同时可以在同一时刻进行批量验证。 接下来&am…...
【网络】什么是速率 (Rate)带宽 (Bandwidth)吞吐量 (Throughput)?
注意单位: 在 kbps、Mbps、Gbps 中,前面的 k、M、G 是 国际单位制(SI) 的前缀,表示不同的数量级: k(千/kilo): (10^3 1,000) kbps(kilobits per second): 每秒 1,000 位(…...
(leetcode算法题)769. 最多能完成排序的块
Q1. 是否能用贪心算法?为什么? 先预设一个策略,每当当前的nums[i]满足可以 "成块",就直接让这个数成块,也就是说之后的遍历过程中不会将这个数在考虑到自己的块内, "成块" 是指只要只…...
高光谱相机的特点
光谱特性 高光谱分辨率:能将光谱范围分割成极窄的波段,光谱分辨率通常达到纳米级甚至亚纳米级,可精确捕捉到不同物质在细微光谱差异上的特征,比如可以区分不同种类的植被因叶绿素含量等差异而在光谱上的细微变化。 多波段探测&a…...
《Spring Framework实战》8:4.1.3.Bean 概述
欢迎观看《Spring Framework实战》视频教程 Spring IoC 容器管理一个或多个 bean。这些 bean 是使用 您提供给容器的配置元数据(例如,以 XML <bean/>定义的形式)。 在容器本身中,这些 bean 定义表示为BeanDefinition对象&a…...
BGP的local_preference本地优先级属性
一、BGP的local preference属性简介 1、local preference公认任意属性 当一条BGP路由器中存在多条去往同一目标网络的BGP路由时,BGP协议会对这些BGP路由属性进行比较,从而筛选出最佳到达目标网络的通达路径。本地优先属性,只在IBGP对等体之间…...
IP地址与端口号
ip地址与端口号 IP地址和端口号是网络通信中的两个重要概念,它们共同构成了网络通信的基础。 IP地址:网络世界的门牌号 定义:IP地址(Internet Protocol Address)是分配给网络设备的数字标签,用于在计算机网…...
Fastapi + vue3 自动化测试平台(2)--日志中间件
FastAPI Vue3 自动化测试平台(2)-- 日志中间件 前言 在开发和运行自动化测试平台时,日志功能是至关重要的一部分。日志不仅能帮助我们快速定位和解决问题,还能作为平台运行的记录依据,为后续分析和优化提供参考。 …...
iOS - AutoreleasePool
1. 基本数据结构 // AutoreleasePool 的基本结构 struct AutoreleasePoolPage {static pthread_key_t const key AUTORELEASE_POOL_KEY;magic_t const magic;id *next; // 指向下一个可存放对象的地址pthread_t const thread; // 所属线程AutoreleasePoolPage …...
1.CSS的复合选择器
1.1 什么是复合选择器 在CSS中,可以根据选择器的类型把选择器分为基础选择器和复合选择器,复合选择器是建立在基础选择器之上,对基础选择器进行组合形成的。 复合选择器可以更精准、更高效的选择目标元素(标签) 复…...
优质内容在个人IP运营中的重要性:以开源AI智能名片商城小程序为应用实例的深度探讨
摘要:在数字化时代,个人品牌(IP)的塑造与传播已成为各行各业提升影响力、吸引用户关注、促进商业转化的关键策略。优质内容作为连接个人IP与目标受众的桥梁,其在个人IP运营中的重要性不言而喻。本文旨在深入探讨优质内…...
网络编程(Modbus进阶)
思维导图 Modbus RTU(先学一点理论) 概念 Modbus RTU 是工业自动化领域 最广泛应用的串行通信协议,由 Modicon 公司(现施耐德电气)于 1979 年推出。它以 高效率、强健性、易实现的特点成为工业控制系统的通信标准。 包…...
基于matlab策略迭代和值迭代法的动态规划
经典的基于策略迭代和值迭代法的动态规划matlab代码,实现机器人的最优运输 Dynamic-Programming-master/Environment.pdf , 104724 Dynamic-Programming-master/README.md , 506 Dynamic-Programming-master/generalizedPolicyIteration.m , 1970 Dynamic-Programm…...
CVE-2020-17519源码分析与漏洞复现(Flink 任意文件读取)
漏洞概览 漏洞名称:Apache Flink REST API 任意文件读取漏洞CVE编号:CVE-2020-17519CVSS评分:7.5影响版本:Apache Flink 1.11.0、1.11.1、1.11.2修复版本:≥ 1.11.3 或 ≥ 1.12.0漏洞类型:路径遍历&#x…...
AirSim/Cosys-AirSim 游戏开发(四)外部固定位置监控相机
这个博客介绍了如何通过 settings.json 文件添加一个无人机外的 固定位置监控相机,因为在使用过程中发现 Airsim 对外部监控相机的描述模糊,而 Cosys-Airsim 在官方文档中没有提供外部监控相机设置,最后在源码示例中找到了,所以感…...
怎么让Comfyui导出的图像不包含工作流信息,
为了数据安全,让Comfyui导出的图像不包含工作流信息,导出的图像就不会拖到comfyui中加载出来工作流。 ComfyUI的目录下node.py 直接移除 pnginfo(推荐) 在 save_images 方法中,删除或注释掉所有与 metadata …...
Web后端基础(基础知识)
BS架构:Browser/Server,浏览器/服务器架构模式。客户端只需要浏览器,应用程序的逻辑和数据都存储在服务端。 优点:维护方便缺点:体验一般 CS架构:Client/Server,客户端/服务器架构模式。需要单独…...
大数据驱动企业决策智能化的路径与实践
📝个人主页🌹:慌ZHANG-CSDN博客 🌹🌹期待您的关注 🌹🌹 一、引言:数据驱动的企业竞争力重构 在这个瞬息万变的商业时代,“快者胜”的竞争逻辑愈发明显。企业如何在复杂环…...
新版NANO下载烧录过程
一、序言 搭建 Jetson 系列产品烧录系统的环境需要在电脑主机上安装 Ubuntu 系统。此处使用 18.04 LTS。 二、环境搭建 1、安装库 $ sudo apt-get install qemu-user-static$ sudo apt-get install python 搭建环境的过程需要这个应用库来将某些 NVIDIA 软件组件安装到 Je…...
Spring事务传播机制有哪些?
导语: Spring事务传播机制是后端面试中的必考知识点,特别容易出现在“项目细节挖掘”阶段。面试官通过它来判断你是否真正理解事务控制的本质与异常传播机制。本文将从实战与源码角度出发,全面剖析Spring事务传播机制,帮助你答得有…...
Qt学习及使用_第1部分_认识Qt---Qt开发基本流程
前言 学以致用,通过QT框架的学习,一边实践,一边探索编程的方方面面. 参考书:<Qt 6 C开发指南>(以下称"本书") 标识说明:概念用粗体倾斜.重点内容用(加粗黑体)---重点内容(红字)---重点内容(加粗红字), 本书原话内容用深蓝色标识,比较重要的内容用加粗倾…...
