新手咨询一下有关 Nestjs 在 Nodejs 中的问题

发布于 1周前 作者 wuwangju 来自 nodejs/Nestjs

如何过滤掉客户端传入的未在 DTO 中定义的字段?现实场景就是前端可能会传入一些我不需要的字段,我希望在 DTO 检验阶段就过滤掉了。另外出参也是一样,比如密码和盐不想返回出去,如果在业务逻辑层去写就太麻烦了。是不是可以通过 DTO 进行过滤一下?
不知道怎么描述这个问题,百度上也没有找到对应的答案,所以在这里问一下。需要有大佬能给我解答一下。另外有没有什么 nest 群想进行学习。
新手咨询一下有关 Nestjs 在 Nodejs 中的问题

17 回复

是我的问题,可以 class-transformer 等等去处理。


我也碰到了这个问题,但是我解决了,稍等我有空回复给你。

密码字段加个 json ignore 注解就行了,后端对象没有对应字段,前端不可能能传进来一个不存在的字段啊

第一个问题不知道开 whitelist 符不符合你的需求,拒绝有多余字段的请求。

第二个问题我是通过中间件中对返回值进行数据清洗实现的,在实体类上用装饰器声明哪一些字段不能返回到前端,在数据清洗方法中检查其元信息删除不需要的字段

入参过滤已经实现了,但是出参对过滤还没有思路

大哥,第二个问题能贴一下代码么。

出参的方式还没有想到,好像可以在拦截器里面处理最后返回的 data 数据

都用 nestjs 了,直接 上 GraphQL 岂不美哉。GraphQL 出参不仅能过滤字段,还附赠强类型 API 文档,配合 CodeGen 客户端类型也省的写了。

这个只听过名字还没有试过,入门难度大么?不过如果能 nestjs 内处理当然最后 nestjs 内的方式咯

对于 Nest.js 应用来说,可以使用 [Code first] 的开发模式,只需增加少量代码即可切换到 GraphQL 。
Nest.js 内置了对 GraphQL 的一流支持,开箱即用: https://docs.nestjs.com/graphql/quick-start
配合 CodeGen( https://the-guild.dev/graphql/codegen ),客户端强类型 API 拿来就用。
用过 GraphQL 再也不会想回到 REST: https://www.apollographql.com/blog/graphql/basics/graphql-vs-rest/

graphql 只是可能看起来好用罢了,都 2023 了,这家伙好不好用前人帮你都把坑踩完了,你用英语搜搜就知道到底风评如何了。

2023 可以试试 tRPC( https://trpc.io/ ),比 GraphQL 要省事儿的多,代价则是牺牲了灵活性。

还是用 transformer 的 exclude 装饰器

如果是用 mikrom ,定义实体的时候可以设置 hidden:true 来让密码之类的字段平时就不读取,只有在需要做校验的时候读取。再然后也可以使用 Interceptor 来对返回的数据做结构调整。然后请求的内容用 class-validator 来做请求的 dto 字段过滤,class-transformer 用来对请求参数做类型转换或设置默认值。

入参的话,可以在 main.ts 中设置 ValidationPipe whitelist :true , 将去掉没有使用任何验证装饰器的属性的验证(返回的)对象

OP 解决了吗?想学习一下

针对你提出的关于Nestjs在Nodejs中的问题,以下是一些关键信息和代码示例:

Nestjs概述

Nestjs是一个用于构建高效、可靠和可扩展的服务器端应用程序的框架。它使用TypeScript(也支持JavaScript)编写,并完全兼容Express.js和Fastify等Node.js框架。

Nestjs安装

要在Nodejs项目中使用Nestjs,首先需要安装它。可以使用npm或yarn进行安装:

npm install -g @nestjs/cli
nest new project-name
cd project-name
npm run start

Nestjs模块化和路由

Nestjs强调模块化,每个逻辑部分都是一个模块。以下是一个简单的模块和路由配置示例:

import { Module } from '@nestjs/common';
import { Controller, Get } from '@nestjs/common';

@Controller('hello')
export class HelloController {
  @Get()
  findAll(): string {
    return 'Hello World!';
  }
}

@Module({
  controllers: [HelloController],
})
export class HelloModule {}

调用Nestjs微服务

在Nodejs应用程序中,可以使用HTTP模块或第三方库(如axios)来调用Nestjs微服务。以下是一个使用axios发送HTTP请求的示例:

const axios = require('axios');

axios.get('http://localhost:3000/hello')
  .then(response => { console.log(response.data); })
  .catch(error => { console.error(error); });

希望这些信息能帮到你!如有其他问题,欢迎继续咨询。

回到顶部