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

2023-12-30 23:33:47

前言

在现代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拦截器的可能性几乎是无限的,可以根据不同的需求定制拦截器。

文章来源:https://blog.csdn.net/m0_37890289/article/details/135310786
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。