gin框架中间件深度解析

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
性能测试 PTS,5000VUM额度
云原生网关 MSE Higress,422元/月
简介: gin框架中间件深度解析

前言

Gin在golang领域是一个非常有名的框架,也是github上面star最高的一个框架,简单易学,效率还高。所以我们大部分web开发都会使用gin框架来进行开发。但是Gin框架里面有一个比较关键的知识点,其中一个就是中间件。(不只是Gin,很多其他框架也是有中间件的概念)

一、中间件的作用

  1. Web请求到到达我们定义的HTTP请求处理方法之前,拦截请求并进行相应处理(比如:权限验证,数据过滤等),这个可以类比为前置拦截器或前置过滤器,
  2. 在我们处理完成请求并响应客户端时,拦截响应并进行相应的处理(比如:添加统一响应部头或数据格式等),这可以类型为后置拦截器或后置过滤器。

二、洋葱模型

在这里插入图片描述
在这里插入图片描述
看上图,我们的中间件就相当于一层一层的洋葱。如果要到洋葱内部,需要一层一层的进入。同理,出来也是一层一层的出来。

三、上代码

知道中间件的作用以及洋葱模型,我们就可以开始撸代码了。

这里以golang作为示例代码。其实只要知道具体的作用,不管用什么代码都是可以徒手写中间件的。

package main

import (
    "fmt"
    "math"
)

const abortIndex = math.MaxInt8 / 2

// 中间件结构体
type Context struct {
    Handlers []func(c *Context) //需要执行的方法切片
    index    int8               //偏移量
}

// 注册方法到中间件
func (this *Context) Use(f func(c *Context)) {
    this.Handlers = append(this.Handlers, f)
}

// 执行下一个方法
func (this *Context) Next() {
    if this.index < int8(len(this.Handlers)) {
        this.index++
        this.Handlers[this.index](this)
    }
}

// 执行handlers里面的第一个方法
func (this *Context) Run() {
    this.Handlers[0](this)
}

func (this *Context) GET(path string, f func(c *Context)) {
    this.Handlers = append(this.Handlers, f)
}

// 终止
func (this *Context) Abort() {
    this.index = abortIndex
}

//主方法
func main() {
    c := &Context{}
    c.Use(MiddlewareOne())
    c.Use(MiddlewareTwo())
    c.GET("/get", func(c *Context) {
        fmt.Println("执行具体方法")
    })
    c.Run()
}

//中间件一
func MiddlewareOne() func(c *Context) {
    return func(c *Context) {
        fmt.Println("MiddlerOne Start")
        c.Next()
        fmt.Println("MiddlerOne End")
    }
}
//中间件二
func MiddlewareTwo() func(c *Context) {
    return func(c *Context) {
        fmt.Println("MiddlerTwo Start")
        c.Next()
        fmt.Println("MiddlerTwo End")
    }
}
//中间件三
func MiddlewareThree() func(c *Context) {
    return func(c *Context) {
        fmt.Println("MiddlerThree Start")
        c.Next()
        fmt.Println("MiddlerThree End")
    }
}

大概讲一下代码的思路。首先我们定义一个中间件结构体,结构体里面分别有两个数据,一个是函数的切片。这个里面会存放所有的中间件函数,第二个是执行函数偏移量。也就是我们在一层层的剥洋葱时的层数,每深入一层,偏移量会加一。

这样我们在执行具体代码的时候的中间件执行顺序如下所示

main-&gt;MiddlewareOne-&gt;MiddlewareTwo-&gt;
那么我们控制台的输出结果就会如下

MiddlerOne Start
MiddlerTwo Start
执行具体方法
MiddlerTwo End
MiddlerOne End
相关文章
|
1月前
|
存储 Java
深入探讨了Java集合框架中的HashSet和TreeSet,解析了两者在元素存储上的无序与有序特性。
【10月更文挑战第16天】本文深入探讨了Java集合框架中的HashSet和TreeSet,解析了两者在元素存储上的无序与有序特性。HashSet基于哈希表实现,添加元素时根据哈希值分布,遍历时顺序不可预测;而TreeSet利用红黑树结构,按自然顺序或自定义顺序存储元素,确保遍历时有序输出。文章还提供了示例代码,帮助读者更好地理解这两种集合类型的使用场景和内部机制。
38 3
|
1月前
|
XML JSON API
ServiceStack:不仅仅是一个高性能Web API和微服务框架,更是一站式解决方案——深入解析其多协议支持及简便开发流程,带您体验前所未有的.NET开发效率革命
【10月更文挑战第9天】ServiceStack 是一个高性能的 Web API 和微服务框架,支持 JSON、XML、CSV 等多种数据格式。它简化了 .NET 应用的开发流程,提供了直观的 RESTful 服务构建方式。ServiceStack 支持高并发请求和复杂业务逻辑,安装简单,通过 NuGet 包管理器即可快速集成。示例代码展示了如何创建一个返回当前日期的简单服务,包括定义请求和响应 DTO、实现服务逻辑、配置路由和宿主。ServiceStack 还支持 WebSocket、SignalR 等实时通信协议,具备自动验证、自动过滤器等丰富功能,适合快速搭建高性能、可扩展的服务端应用。
108 3
|
19天前
|
消息中间件 NoSQL Java
springboot整合常用中间件框架案例
该项目是Spring Boot集成整合案例,涵盖多种中间件的使用示例,每个案例项目使用最小依赖,便于直接应用到自己的项目中。包括MyBatis、Redis、MongoDB、MQ、ES等的整合示例。
77 1
|
1月前
|
消息中间件 中间件 数据库
NServiceBus:打造企业级服务总线的利器——深度解析这一面向消息中间件如何革新分布式应用开发与提升系统可靠性
【10月更文挑战第9天】NServiceBus 是一个面向消息的中间件,专为构建分布式应用程序设计,特别适用于企业级服务总线(ESB)。它通过消息队列实现服务间的解耦,提高系统的可扩展性和容错性。在 .NET 生态中,NServiceBus 提供了强大的功能,支持多种传输方式如 RabbitMQ 和 Azure Service Bus。通过异步消息传递模式,各组件可以独立运作,即使某部分出现故障也不会影响整体系统。 示例代码展示了如何使用 NServiceBus 发送和接收消息,简化了系统的设计和维护。
48 3
|
15天前
|
存储 Java 开发者
Java中的集合框架深入解析
【10月更文挑战第32天】本文旨在为读者揭开Java集合框架的神秘面纱,通过深入浅出的方式介绍其内部结构与运作机制。我们将从集合框架的设计哲学出发,探讨其如何影响我们的编程实践,并配以代码示例,展示如何在真实场景中应用这些知识。无论你是Java新手还是资深开发者,这篇文章都将为你提供新的视角和实用技巧。
12 0
|
1月前
|
Web App开发 IDE 测试技术
自动化测试的利器:Selenium 框架深度解析
【10月更文挑战第2天】在软件开发的海洋中,自动化测试犹如一艘救生艇,让质量保证的过程更加高效与精准。本文将深入探索Selenium这一强大的自动化测试框架,从其架构到实际应用,带领读者领略自动化测试的魅力和力量。通过直观的示例和清晰的步骤,我们将一起学习如何利用Selenium来提升软件测试的效率和覆盖率。
|
1月前
|
人工智能 缓存 Java
深入解析Spring AI框架:在Java应用中实现智能化交互的关键
【10月更文挑战第12天】Spring AI 是 Spring 框架家族的新成员,旨在满足 Java 应用程序对人工智能集成的需求。它支持自然语言处理、图像识别等多种 AI 技术,并提供与云服务(如 OpenAI、Azure Cognitive Services)及本地模型的无缝集成。通过简单的配置和编码,开发者可轻松实现 AI 功能,同时应对模型切换、数据安全及性能优化等挑战。
108 3
|
1月前
|
分布式计算 Java 应用服务中间件
NettyIO框架的深度技术解析与实战
【10月更文挑战第13天】Netty是一个异步事件驱动的网络应用程序框架,由JBOSS提供,现已成为Github上的独立项目。
44 0
|
5月前
|
消息中间件 存储 中间件
【消息中间件】详解三大MQ:RabbitMQ、RocketMQ、Kafka
【消息中间件】详解三大MQ:RabbitMQ、RocketMQ、Kafka
1424 0
|
4月前
|
消息中间件 编解码 Docker
Docker部署RabbitMQ消息中间件
【7月更文挑战第4天】Docker部署RabbitMQ消息中间件
277 3

推荐镜像

更多
下一篇
无影云桌面