一篇文章学会如何使用 NestJS 的 Interceptor 拦截器并且附带实战操作案例

前言

在现代Web开发的世界中,NestJS以其灵活性和强大的功能立足,成为Node.js框架的佼佼者。其中一个引人注目的功能就是拦截器,这是一种可以让开发者更好地控制和补充HTTP请求循环的工具。拦截器让开发者可以在处理程序之前或之后“拦截”HTTP请求,这是解决一系列问题的基石。

什么是NestJS拦截器

简单来说,拦截器是一种特殊类型的服务,运行在路由处理程序方法之前和之后。它们在每次请求和响应的生命周期中都被调用,能够在请求处理之前进行操作,或对从处理程序返回的响应进行转换。

你可以将其视为中间件的一种更先进的形式,它们在每次请求和响应的生命周期中都被运行。

NestJS拦截器的用途

NestJS拦截器的常见用途包括:

1. 修改响应数据

统一所有响应数据的格式,为其添加相同的结构或者字段。

2. 请求预处理

实现认证和授权逻辑,或对请求数据进行初步校验。

3. 性能调优

计算处理请求所需的时间,为优化性能提供依据。

4. 日志记录

记录每次请求及响应的详细数据,为问题排查提供信息。

实际案例

下面,我们将通过一些具体的案例来了解如何在实际项目中使用NestJS拦截器。

1. 响应数据的统一处理

在这个案例中,我们希望所有的HTTP响应都有一个 code字段和 data字段。我们可以通过创建一个拦截器来执行此操作:

import { Injectable, NestInterceptor, ExecutionContext, CallHandler } from '@nestjs/common';
import { Observable } from 'rxjs';
import { map } from 'rxjs/operators';

@Injectable()
export class TransformInterceptor implements NestInterceptor {
  intercept(context: ExecutionContext, next: CallHandler): Observable<any> {
    return next
      .handle()
      .pipe(
        map(data => ({ code: 200, data })),
      );
  }
}

这是执行后的结果:

{
  "code": 200,
  "data": {/* 原来的响应数据 */}
}

2. 记录处理时间

此拦截器可用于记录处理请求所需的时间,对于性能优化非常有用:

import { Injectable, NestInterceptor, ExecutionContext, CallHandler } from '@nestjs/common';
import { Observable } from 'rxjs';
import { tap } from 'rxjs/operators';

@Injectable()
export class TimingInterceptor implements NestInterceptor {
  intercept(context: ExecutionContext, next: CallHandler): Observable<any> {
    const now = Date.now();
    return next
      .handle()
      .pipe(
        tap(() => console.log(`After... ${Date.now() - now}ms`)),
      );
  }
}

执行的结果可能如下:

After... 27ms

总结

以上就是对NestJS拦截器的详细介理解和使用案例。掌握了拦截器,我们可以在处理请求时有更多的操作空间。虽然这只是NestJS的众多特性之一,但其强大的潜力表明了它在构建现代Web应用程序时的价值。

使用NestJS开发应用程序是一种愉快的体验,而拦截器无疑大大增强了它的功能,使我们可以更好地控制和管理HTTP请求。这只是NestJS的一小部分,但却能大大提升你的开发效率。

此外,此处提供的使用案例只是冰山一角,实际上,NestJS拦截器的可能性几乎是无限的,可以根据不同的需求定制拦截器。

  • 10
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

乐闻x

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值