Edit:
我看过这个问题/答案如何从控制器 json 中排除实体字段 https://stackoverflow.com/questions/50360101/how-to-exclude-entity-field-from-returned-by-controller-json-nestjs-typeorm
但是,如下所示 - 这将从所有查询中排除该字段(在尝试处理用户验证时,在不具有 ClassSerializerInterceptor 的路由/控制器方法上使用 findOne 存储库查询排除密码字段
我在 Nest.js / typeorm 中有一个实体;我试图从返回的 json 中排除密码字段,但不从我的服务中的任何存储库查询中排除密码字段。例如:
user.entity.ts
:
import { Entity, Column, PrimaryGeneratedColumn, CreateDateColumn,
UpdateDateColumn, ManyToOne } from 'typeorm';
import { Exclude } from 'class-transformer';
import { Account } from '../accounts/account.entity';
@Entity()
export class User {
@PrimaryGeneratedColumn('uuid')
id: string;
@Column()
firstName: string;
@Column()
lastName: string;
@Column({
unique: true,
})
email: string;
@Column()
password: string;
}
auth.controller.ts
:
import { Controller, Post, Body, Request, Req, Get, UseInterceptors, ClassSerializerInterceptor, UseGuards } from '@nestjs/common';
import { AuthGuard } from '@nestjs/passport';
import { AuthService } from './auth.service';
import { IUserRequest } from '../../interfaces/user-request.interface';
@Controller('auth')
export class AuthController {
constructor(private readonly authService: AuthService) {}
@Post('/login')
async login(@Request() req: Request) {
const user = await this.authService.checkCredentials(req.body);
return this.authService.logUserIn(user.id);
}
@Get('/profile')
@UseGuards(AuthGuard())
@UseInterceptors(ClassSerializerInterceptor)
async profile(@Request() req: IUserRequest) {
const profile = await this.authService.getLoggedInProfile(req.user.id);
return { profile };
}
}
如果我添加Exclude()
像这样输入密码
@Exclude()
@Column()
password: string;
密码包含在响应中
如果我删除Column()
从密码,
@Exclude()
password: string;
密码不包含在响应中and所有内部查询,例如:
const user = await this.userRepository.findOne({ where: { id }, relations: ['account']});
在 Nest.js 中使用以下方法可能吗?ClassSerializerInterceptor
?
如果是这样,希望您能指出正确的方向。