我已经在 NestJS 中间件中应用了身份验证,并通过第三方 API 从用户令牌中解码了所有信息。
现在我已经在我的中间件中获得了信息,我如何将这些信息发送到控制器和服务?
我已经在 NestJS 中间件中应用了身份验证,并通过第三方 API 从用户令牌中解码了所有信息。
现在我已经在我的中间件中获得了信息,我如何将这些信息发送到控制器和服务?
中间件向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);
}
从那里您可以确保您的服务方法将用户作为常规方法参数接收