news 2026/2/18 7:39:13

NestJs-拦截器

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
NestJs-拦截器

NestJS 拦截器概述

拦截器(Interceptor)是 NestJS 的核心功能之一,用于在方法执行前后添加额外的逻辑。拦截器基于面向切面编程(AOP)思想,常用于日志记录、性能监控、响应格式统一等场景。

拦截器的核心功能

  • 方法执行前/后注入逻辑:可以在目标方法执行前后插入自定义代码。
  • 修改请求/响应数据:拦截请求或响应的数据流并对其进行转换。
  • 异常处理:捕获并处理目标方法抛出的异常。
  • 异步拦截:支持ObservablePromise的异步操作。

创建拦截器

拦截器是一个实现了NestInterceptor接口的类,需使用@Injectable()装饰器。核心方法是intercept,接收两个参数:

  • context: ExecutionContext:提供当前请求的上下文信息。
  • next: CallHandler:调用目标方法的控制器逻辑。
import{CallHandler,ExecutionContext,Injectable,NestInterceptor}from'@nestjs/common';import{map,Observable}from'rxjs';@Injectable()exportclassSerializeInterceptorimplementsNestInterceptor{intercept(context:ExecutionContext,next:CallHandler):Observable<any>{console.log('拦截器执行之前')constreq=context.switchToHttp().getRequest();console.log('请求对象',req)returnnext.handle().pipe(map((data)=>{console.log('拦截器执行之后')console.log('数据',data)returndata}));}}

注册拦截器

拦截器可以全局注册、模块注册或方法级注册:

全局注册

main.ts中使用SerializeInterceptor

app.useGlobalInterceptors(newSerializeInterceptor());
模块注册

通过模块的providers数组注册,并标记为可注入:

@Module({providers:[{provide:APP_INTERCEPTOR,useClass:SerializeInterceptor,},],})exportclassAppModule{}
方法级注册

直接在控制器方法上使用@UseInterceptors装饰器:

@Controller('users')exportclassUsersController{@UseInterceptors(SerializeInterceptor)@Get()findAll(){/* ... */}}

常见应用场景

统一响应格式

通过拦截器将控制器返回的数据包装为固定格式:

@Injectable()exportclassTransformInterceptorimplementsNestInterceptor{intercept(context:ExecutionContext,next:CallHandler):Observable<any>{returnnext.handle().pipe(map(data=>({success:true,data})));}}
性能监控

记录方法执行耗时:

@Injectable()exportclassTimingInterceptorimplementsNestInterceptor{intercept(context:ExecutionContext,next:CallHandler):Observable<any>{conststart=Date.now();returnnext.handle().pipe(tap(()=>console.log(`Execution time:${Date.now()-start}ms`)),);}}
缓存拦截

实现简单的缓存逻辑:

@Injectable()exportclassCacheInterceptorimplementsNestInterceptor{privatecache=newMap<string,any>();intercept(context:ExecutionContext,next:CallHandler):Observable<any>{constrequest=context.switchToHttp().getRequest();constkey=request.url;if(this.cache.has(key)){returnof(this.cache.get(key));}returnnext.handle().pipe(tap((data)=>this.cache.set(key,data)),);}}

高级用法

修改请求数据

通过拦截器预处理请求参数:

@Injectable()exportclassSanitizeInterceptorimplementsNestInterceptor{intercept(context:ExecutionContext,next:CallHandler):Observable<any>{constrequest=context.switchToHttp().getRequest();request.body=this.sanitize(request.body);returnnext.handle();}privatesanitize(data:any){// 实现数据清洗逻辑returndata;}}
异步拦截

结合rxjs操作符处理异步流:

@Injectable()exportclassTimeoutInterceptorimplementsNestInterceptor{intercept(context:ExecutionContext,next:CallHandler):Observable<any>{returnnext.handle().pipe(timeout(5000),// 5秒超时catchError((err)=>throwError(newRequestTimeoutException())),);}}

小栗子

实现请求敏感信息的过滤

import{CallHandler,ExecutionContext,Injectable,NestInterceptor}from'@nestjs/common';import{plainToInstance}from'class-transformer';import{map,Observable}from'rxjs';@Injectable()exportclassSerializeInterceptorimplementsNestInterceptor{constructor(privatedto?:any){}intercept(context:ExecutionContext,next:CallHandler):Observable<any>{console.log('拦截器执行之前')constreq=context.switchToHttp().getRequest();console.log('请求对象',req)returnnext.handle().pipe(map((data)=>{console.log('拦截器执行之后')console.log('数据',data)returnplainToInstance(this.dto,data,{// Expose 设置暴露字段// Exclude 设置排除字段excludeExtraneousValues:true,// 设置为true之后,所有经过拦截器的接口都需要设置Expose或者Exclude})}));}}

拦截器与过滤器的区别

  • 拦截器:作用于方法调用前后,可修改请求/响应数据流。
  • 异常过滤器:仅捕获异常,无法修改正常流程的数据。

最佳实践

  • 避免在拦截器中实现业务逻辑,保持职责单一。
  • 优先使用模块注册而非全局注册,便于测试和依赖管理。
  • 对于性能敏感的拦截器,可通过缓存减少重复计算。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/16 13:41:00

RN Navigation vs Vue Router:从架构底层到工程实践的深度对比

[toc] 前言&#xff1a;这不是“谁更好”&#xff0c;而是“谁解决的问题不同” 很多团队在同时做 Web 和 RN 项目时&#xff0c;都会下意识问一句&#xff1a;Vue Router 这套东西&#xff0c;在 RN 里能不能也照着来&#xff1f;如果你只是做 Demo&#xff0c;答案是「看起来…

作者头像 李华
网站建设 2026/2/17 13:29:47

廊坊的婚介所靠谱吗?

我叫林晓阳&#xff0c;28岁&#xff0c;廊坊某科技公司程序员。三年前在相亲角遇到现在的丈夫&#xff0c;但那次经历让我对婚恋市场产生了深刻的认知。那年我抱着试试看的心态&#xff0c;走进了当地最大的婚介所。接待我的姑娘笑容甜美&#xff0c;递来一份精心设计的问卷&a…

作者头像 李华
网站建设 2026/2/11 16:49:14

新能源与燃油汽车对比数据可视化分析

新能源与燃油汽车对比数据可视化分析 1. 项目概述 本项目旨在通过数据挖掘技术,深入分析中国汽车市场中新能源汽车(EV)与传统燃油汽车(Gasoline)的竞争格局、销售趋势及关键影响因素。系统集成了数据预处理、探索性数据分析(EDA)、机器学习销量预测模型以及交互式Web可…

作者头像 李华
网站建设 2026/2/16 4:21:41

37、UNIX系统用户管理与支持全攻略

UNIX系统用户管理与支持全攻略 1. 用小事留下大印象 在与用户的交互中,一些看似微不足道的小事往往能给用户留下深刻的印象。以下是几个具体的方法: 1.1 倾听用户 作为管理员,日常工作总是十分繁忙,任务清单上总有做不完的事情。无论是在走廊上偶遇用户,还是用户打电话…

作者头像 李华
网站建设 2026/2/5 16:18:32

38、UNIX系统用户管理与故障处理全攻略

UNIX系统用户管理与故障处理全攻略 1 UNIX系统中的故障类型及时间预估 在使用UNIX服务器时,故障停机是难以避免的情况,而且要配合用户的使用时间来安排故障处理往往颇具挑战。常见的故障类型有以下三种: - 定期计划故障 :在生产环境中,这些是固定的停机时间,所有用户…

作者头像 李华
网站建设 2026/2/5 10:44:17

39、深入了解 UNIX 系统管理职业:层级、要求与发展路径

深入了解 UNIX 系统管理职业:层级、要求与发展路径 1. 引言 UNIX 系统管理工作涵盖了诸多方面,如求职、应对面试、面试候选人等。同时,还涉及与供应商、销售代表、响应中心、帮助台以及支持工程师的协作。这份工作远不止坐在终端前那么简单,接下来我们将详细了解 UNIX 系…

作者头像 李华