Gin框架中的全局中间件与中间件传值

2024-09-04 15:12

本文主要是介绍Gin框架中的全局中间件与中间件传值,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Gin是一个用Go语言编写的Web框架,它以高性能和简洁的API而闻名。在Gin中,中间件是一种在请求处理流程中执行特定任务的函数,这些任务可能包括日志记录、用户认证、请求限流等。中间件可以在全局范围内使用,也可以仅应用于特定的路由或路由组。

全局中间件

全局中间件会应用于所有的请求,无论请求的路径是什么。在Gin中,可以通过r.Use()方法来注册全局中间件。注册的中间件会按照它们注册的顺序执行。

中间件传值

Gin的中间件可以通过上下文(*gin.Context)来传递数据。上下文是一个包含了请求和响应的封装,它允许中间件和处理函数之间传递数据。使用c.Set()方法可以在上下文中存储数据,而c.Get()c.MustGet()方法则用于从上下文中获取数据。

示例代码解析

以下是一个使用Gin框架的示例代码,展示了如何定义全局中间件以及如何在中间件之间传递数据。

package mainimport ("fmt""github.com/gin-gonic/gin"
)// User 定义了一个用户结构体,包含姓名和年龄
type User struct {Name stringAge  int
}// m10 是一个中间件函数,用于设置上下文数据
func m10(c *gin.Context) {fmt.Println("m10...in")// 使用c.Set向gin的上下文中存储数据c.Set("num", 10)c.Set("user", User{"zhangsan", 18})// 调用c.Next()来执行下一个中间件或路由处理函数c.Next()fmt.Println("m10...out")
}// m11 是一个中间件函数,用于获取上下文数据
func m11(c *gin.Context) {fmt.Println("m11...in")// 使用c.Get从gin的上下文中获取数据,exists用于判断数据是否存在value, exists := c.Get("num")if exists {fmt.Println(value)}// c.MustGet确保数据一定存在,如果不存在会返回一个panicfmt.Println(c.MustGet("user"))_user, _ := c.Get("user")// 类型断言,将接口类型转换为User类型,并访问Name字段fmt.Println(_user.(User).Name)// 调用c.Next()来执行下一个中间件或路由处理函数c.Next()fmt.Println("m11...out")
}func main() {// 创建默认的gin路由器r := gin.Default()// 使用r.Use将m10和m11中间件绑定到每个请求中r.Use(m10, m11)// 定义路由/m10,响应GET请求,返回JSON数据r.GET("/m10", func(c *gin.Context) {c.JSON(200, gin.H{"msg": "m10"})})// 定义路由/m11,响应GET请求,返回JSON数据r.GET("/m11", func(c *gin.Context) {c.JSON(200, gin.H{"msg": "m11"})})// 启动gin服务器,监听localhost的8080端口r.Run("localhost:8080")
}

运行结果

当访问/m11路由时,控制台输出如下:

m10...in
m11...in
10
{zhangsan 18}
zhangsan
m11...out
m10...out

总结

通过这个示例,我们可以看到如何在Gin中使用全局中间件以及如何在中间件之间传递数据。m10中间件在请求处理流程的早期设置数据,而m11中间件则在稍后获取并使用这些数据。这种模式在处理跨请求的共享数据时非常有用。

这篇关于Gin框架中的全局中间件与中间件传值的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1136317

相关文章

Python3中Sanic中间件的使用

《Python3中Sanic中间件的使用》Sanic框架中的中间件是一种强大的工具,本文就来介绍Python3中Sanic中间件的使用,具有一定的参考价值,感兴趣的可以了解一下... 目录Sanic 中间件的工作流程中间件的使用1. 全局中间件2. 路由中间件3. 异常处理中间件4. 异步中间件5. 优先级

MyBatis框架实现一个简单的数据查询操作

《MyBatis框架实现一个简单的数据查询操作》本文介绍了MyBatis框架下进行数据查询操作的详细步骤,括创建实体类、编写SQL标签、配置Mapper、开启驼峰命名映射以及执行SQL语句等,感兴趣的... 基于在前面几章我们已经学习了对MyBATis进行环境配置,并利用SqlSessionFactory核

cross-plateform 跨平台应用程序-03-如果只选择一个框架,应该选择哪一个?

跨平台系列 cross-plateform 跨平台应用程序-01-概览 cross-plateform 跨平台应用程序-02-有哪些主流技术栈? cross-plateform 跨平台应用程序-03-如果只选择一个框架,应该选择哪一个? cross-plateform 跨平台应用程序-04-React Native 介绍 cross-plateform 跨平台应用程序-05-Flutte

Spring框架5 - 容器的扩展功能 (ApplicationContext)

private static ApplicationContext applicationContext;static {applicationContext = new ClassPathXmlApplicationContext("bean.xml");} BeanFactory的功能扩展类ApplicationContext进行深度的分析。ApplicationConext与 BeanF

数据治理框架-ISO数据治理标准

引言 "数据治理"并不是一个新的概念,国内外有很多组织专注于数据治理理论和实践的研究。目前国际上,主要的数据治理框架有ISO数据治理标准、GDI数据治理框架、DAMA数据治理管理框架等。 ISO数据治理标准 改标准阐述了数据治理的标准、基本原则和数据治理模型,是一套完整的数据治理方法论。 ISO/IEC 38505标准的数据治理方法论的核心内容如下: 数据治理的目标:促进组织高效、合理地

ZooKeeper 中的 Curator 框架解析

Apache ZooKeeper 是一个为分布式应用提供一致性服务的软件。它提供了诸如配置管理、分布式同步、组服务等功能。在使用 ZooKeeper 时,Curator 是一个非常流行的客户端库,它简化了 ZooKeeper 的使用,提供了高级的抽象和丰富的工具。本文将详细介绍 Curator 框架,包括它的设计哲学、核心组件以及如何使用 Curator 来简化 ZooKeeper 的操作。 1

【Kubernetes】K8s 的安全框架和用户认证

K8s 的安全框架和用户认证 1.Kubernetes 的安全框架1.1 认证:Authentication1.2 鉴权:Authorization1.3 准入控制:Admission Control 2.Kubernetes 的用户认证2.1 Kubernetes 的用户认证方式2.2 配置 Kubernetes 集群使用密码认证 Kubernetes 作为一个分布式的虚拟

Spring Framework系统框架

序号表示的是学习顺序 IoC(控制反转)/DI(依赖注入): ioc:思想上是控制反转,spring提供了一个容器,称为IOC容器,用它来充当IOC思想中的外部。 我的理解就是spring把这些对象集中管理,放在容器中,这个容器就叫Ioc这些对象统称为Bean 用对象的时候不用new,直接外部提供(bean) 当外部的对象有关系的时候,IOC给它俩绑好(DI) DI和IO

开源分布式数据库中间件

转自:https://www.csdn.net/article/2015-07-16/2825228 MyCat:开源分布式数据库中间件 为什么需要MyCat? 虽然云计算时代,传统数据库存在着先天性的弊端,但是NoSQL数据库又无法将其替代。如果传统数据易于扩展,可切分,就可以避免单机(单库)的性能缺陷。 MyCat的目标就是:低成本地将现有的单机数据库和应用平滑迁移到“云”端

Sentinel 高可用流量管理框架

Sentinel 是面向分布式服务架构的高可用流量防护组件,主要以流量为切入点,从限流、流量整形、熔断降级、系统负载保护、热点防护等多个维度来帮助开发者保障微服务的稳定性。 Sentinel 具有以下特性: 丰富的应用场景:Sentinel 承接了阿里巴巴近 10 年的双十一大促流量的核心场景,例如秒杀(即突发流量控制在系统容量可以承受的范围)、消息削峰填谷、集群流量控制、实时熔断下游不可用应