【Nest全栈之旅】第六章:拦截器知多少?🙅🏻‍♀️🙅🏻‍♀️🙅🏻‍♀️

前言

顾名思义,拦截器可以在执行应用程序之前或之后插入额外的逻辑,拦截器是AOP编程思想的体现,它可以做以下事情:

  • 在方法执行之前/之后绑定额外的逻辑
  • 转换函数返回的结果
  • 转换函数抛出的异常
  • 扩展基本功能行为
  • 根据特定条件完全覆盖函数(例如,出于缓存目的)

Nest中的拦截器

Nest中,拦截器需要实现NestInterceptor类的intercept方法,它接受两个参数,一个是拦截器执行上下文ExecutionContext,它里面添加了一些方法用于获取更多关于拦截器的详细信息,如获取当前是由哪个或者方法调用拦截器;第二个参数是CallHandler,也叫应用处理程序,例如在controller中的路由处理方法findOne,我们来验证一下上面两点:

这里我自定义一个耗时统计拦截器(后面再讲),用于拦截PersonController这个控制器,它会拦截这里的所有方法,通过ExecutionContext获取拦截器装饰的方法

TimeoutInterceptor里面会统计方法耗时并且打印是哪个路由方法触发了拦截器

在前端先后发送两个请求调用接口

来看看结果

当然,我们也可以知道是哪个类绑定了拦截器,通过getClass方法获取

所以,由此我们可以知道拦截器可以绑定一个控制器作用域、方法作用域,其实还有一个就是全局作用域,即在全局绑定的拦截器,是应用到所有的路由方法中,比如全局绑定响应拦截器,那么就可以统一返回前端的数据结构:

自定义拦截器

这里我们自定义了一个统计方法耗时的拦截器

从上面的自定义拦截器中,我们可以看到通过返回next.handle()可以让路由处理方法可以继续执行,同时这里涉及到一系列方式对数据进行操作,如taptimeoutmapfilter等,它们来自Rxjs库。

Rxjs是一个组织异步的库,它里面有很多操作方法,使用它可以很方便来操作一些逻辑,角色譬如lodash

有人会说,这些方法自己都可以实现啦,的确是的,但是不得不说Rxjs里面提供了太多的方法,用的越多效率越高。

那这样会不会提高心智负担呢?答案是基本上不会,因为实际上常用到的方法也就那么几个,如tapmaptimeoutcatchErrorfilter这几个。

总结

拦截器需要实现NestInterceptor类的intercept方法,而在Nest中,可以便利的使用Rxjs里面的操作方法来实现自定义拦截器功能。

拦截器是有控制范围的,它可以在控制器作用域、方法作用域和全局作用域中使用拦截器,控制器作用域只能控制某个拦截器里面的路由处理函数,而全局拦截器可以拦截所有控制器的路由处理函数,例如异常拦截器响应拦截器会挂在全局进行统一控制。

相关推荐
想用offer打牌2 小时前
MCP (Model Context Protocol) 技术理解 - 第二篇
后端·aigc·mcp
崔庆才丨静觅2 小时前
hCaptcha 验证码图像识别 API 对接教程
前端
passerby60613 小时前
完成前端时间处理的另一块版图
前端·github·web components
KYGALYX3 小时前
服务异步通信
开发语言·后端·微服务·ruby
掘了3 小时前
「2025 年终总结」在所有失去的人中,我最怀念我自己
前端·后端·年终总结
崔庆才丨静觅3 小时前
实用免费的 Short URL 短链接 API 对接说明
前端
崔庆才丨静觅3 小时前
5分钟快速搭建 AI 平台并用它赚钱!
前端
爬山算法4 小时前
Hibernate(90)如何在故障注入测试中使用Hibernate?
java·后端·hibernate
崔庆才丨静觅4 小时前
比官方便宜一半以上!Midjourney API 申请及使用
前端
Moment4 小时前
富文本编辑器在 AI 时代为什么这么受欢迎
前端·javascript·后端