1

我已经在 NestJS 中间件中应用了身份验证,并通过第三方 API 从用户令牌中解码了所有信息。

现在我已经在我的中间件中获得了信息,我如何将这些信息发送到控制器和服务?

4

1 回答 1

2

中间件向request对象添加信息是正常的(例如,添加用户对象)。

对于从请求对象中提取信息并将其注入控制器的干净方法,您可以制作自定义路由装饰器

例如,提取用户:

import { createParamDecorator, ExecutionContext } from '@nestjs/common';

export const User = createParamDecorator(
  (data: unknown, ctx: ExecutionContext) => {
    const request = ctx.switchToHttp().getRequest();
    return request.user;
  },
);

然后在你的控制器中

@Get()
async findOne(@User() user: UserEntity) {
  console.log(user);
}

从那里您可以确保您的服务方法将用户作为常规方法参数接收

于 2021-07-29T15:13:34.910 回答