王中阳Go

V1

2022/11/14阅读:17主题:橙心

【Go电商实战05】中间件的概念和应用 结合项目解答使用中的问题

我会把Go语言中的知识点结合商业项目,让大家理论联系实践,更好的学习理解,高效学,少踩坑。

上期回顾

上一篇内容分享了【电商实战04】ORM链式操作的字段过滤&为什么GoFrame不支持migrate功能?

如果你第一次看我【电商实战】系列的文章,建议先看【电商实战系列】先看这里:适合人群&课程大纲&开源地址&视频合集&一起学习

看过的朋友请忽略,继续往下看:

本期重点

用到的知识点包括:

  • 中间件的概念和应用
  • GoFrame中间件/拦截器的基本介绍
  • GoFrame中间件/拦截器的使用示例
  • 结合商业项目,视频答疑读者使用中遇到的问题

什么是中间件?

在服务端开发中,“中间件”是大家一定会听到的名词。

初学者听起来觉得很高大上,觉得很难,其实“中间件”并不难,对我们学习Go语言来说,使用中间件也没有太多心智挑战。

“中间件”它并没有很严格的定义,但是普遍接受IDC的定义:中间件是一种独立的系统软件服务程序,分布式应用软件借助这种软件在不同的技术之间共享资源,中间件位于客户机服务器的操作系统之上,管理计算资源和网络通信。

比如:

  1. 我们今天要重点介绍的“GoFrame网络请求控制中间件”是中间件的一种,它是基于GoFrame框架内部的一种中间件,也是我们这期内容的重点。

  2. 在我们WEB开发过程中,像常用的MySQL、Redis、RabbitMQ在系统架构角度也被称为中间件。

从基础架构、系统架构、程序架构等不同的观点来看,中间件的概念是不一样的。我们也不用过于纠结于这个名词的具体解释。

毕竟结合自己的需求,掌握如何使用中间件,远比只搞清楚中间件的解释要有意义的多。

更多介绍大家可以查看:中间件-计算机用语--百度百科[1],不作为我这期内容的重点。

GoFrame中间件/拦截器-基本介绍

GoFrame提供了优雅的中间件请求控制方式,该方式也是主流的WebServer提供的请求流程控制方式,基于中间件设计可以为WebServer提供更灵活强大的插件机制。

经典的中间件洋葱模型:

中间件定义

中间件的定义和普通HTTP执行方法HandlerFunc一样,但是可以在Request参数中使用Middleware属性对象来控制请求流程。

我们拿一个跨域请求的中间件定义来示例说明一下:

func MiddlewareCORS(r *ghttp.Request) {
 r.Response.CORSDefault()
 r.Middleware.Next()
}

可以看到在该中间件中执行完成跨域请求处理的逻辑后,使用r.Middleware.Next()方法进一步执行下一个流程;如果这个时候直接退出不调用r.Middleware.Next()方法的话,将会退出后续的执行流程(例如可以用于请求的鉴权处理)。

中间件类型

中间件的类型分为两种:前置中间件和后置中间件。前置即在路由服务函数调用之前调用,后置即在其后调用。

前置中间件

其定义类似于:

func Middleware(r *ghttp.Request) {
 // 中间件处理逻辑
 r.Middleware.Next()
}

后置中间件

其定义类似于:

func Middleware(r *ghttp.Request) {
 r.Middleware.Next()
 // 中间件处理逻辑
}

按照中间件注册方式划分,又可分为:全局中间件、分组路由中间件。

全局中间件

func (s *Server) Use(handlers ...HandlerFunc)

全局中间件是可以独立使用的请求拦截方法,通过路由规则的方式进行注册,绑定到Server上,由于中间件需要执行请求拦截操作,因此往往是使用"模糊匹配"或者"命名匹配"规则。

全局中间件仅对动态请求拦截有效,无法拦截静态文件请求。

分组路由中间件

func (g *RouterGroup) Middleware(handlers ...HandlerFunc) *RouterGroup

分组路由中注册的中间件绑定到当前分组路由中的所有的服务请求上,当服务请求被执行前会调用到其绑定的中间件方法。

分组路由仅有一个Middleware的中间件注册方法。分组路由中间件与全局中间件不同之处在于,分组路由中间件无法独立使用,必须在分组路由注册中使用,并且绑定到当前分组路由中所有的路由上作为路由方法的一部分。

执行优先级

全局中间件

由于全局中间件也是通过路由规则执行,那么也会存在执行优先级:

  1. 首先,由于全局中间件是基于模糊路由匹配,因此当同一个路由匹配到多个中间件时,会按照路由的深度优先规则执行,具体请查看路由章节;
  2. 其次,同一个路由规则下,会按照中间件的注册先后顺序执行,中间件的注册方法也支持同时按照先后顺序注册多个中间件;
  3. 最后,为避免优先级混淆和后续管理,建议将所有中间件放到同一个地方进行先后顺序注册来控制执行优先级;

这里的建议来参考于gRPC的拦截器设计,没有过多的路由控制,仅在一个地方同一个方法统一注册。往往越简单,越容易理解,也便于长期维护。

分组路由中间件

分组路由中间件是绑定到分组路由上的服务方法,不存在路由规则匹配,因此只会按照注册的先后顺序执行。

示例

官方文档为我们提供了比较详细的示例,包括:

  1. 允许跨域请求
  2. 请求鉴权处理
  3. 鉴权例外处理
  4. 统一的错误处理
  5. 自定义日志处理

大家感兴趣可以直接查看:官方示例文档[2],不作为我这期内容的重点。

视频

我的视频结合了「电商实战」项目,回答了读者在使用GoFrame开发过程中的疑问:

  1. 用到的知识点就包括前文重点提到的“GoFrame中间件”
  2. “api层结构体中定义接口URL和请求方式是如何与controller层中的方法关联上的呢?”
  3. “为什么cmd中路由绑定只是绑定到controller层对象这一层就可以?”

B站免费视频合集:【Go电商实战05】中间件的使用-路由绑定-自定义返回json

一起学习

公众号:程序员升级打怪之旅

微信号:wangzhongyang1993

B站视频:王中阳Go

参考资料

[1]

中间件-计算机用语--百度百科: https://baike.baidu.com/item/%E4%B8%AD%E9%97%B4%E4%BB%B6/452240?fr=aladdin

[2]

官方示例文档: https://goframe.org/pages/viewpage.action?pageId=55289886

分类:

后端

标签:

Golang

作者介绍

王中阳Go
V1

专注Go语言开发