首页
学习
活动
专区
圈层
工具
发布

Nest.js 实战 (三):使用 Swagger 优雅地生成 API 文档

、统一的结构,用于跨各种描述语言和序列化格式描述 API Nest 集成 Swagger 1、 安装依赖 pnpm add @nestjs/swagger swagger-ui-express 2、..., SwaggerModule } from '@nestjs/swagger'; import { AppModule } from '....{ ApiOkResponse, ApiOperation, ApiTags } from '@nestjs/swagger'; // swagger 接口文档 import { PostParamsDto...、请求参数或响应参数,包括名称、类型、描述等 @ApiBody 指定请求体的 DTO 类型,用于描述请求体的结构 @ApiResponse 描述 API 的响应,包括状态码、描述等 @ApiBearerAuth...描述请求头信息,包括名称、类型、描述等 @ApiExcludeEndpoint 标记一个控制器方法不在 Swagger UI 中显示 效果图 总结 在 Nest 中集成 Swagger 文档可以帮助开发者自动生成和维护

1.1K11
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    重构kz-admin

    依赖升级​ 我原先的nestjs依赖是8.0.0,但是技术发展太快,nestjs 9.0.0都已经发布了,所以这次更新属于大版本更新,通常属于破坏性更新,可能会导致原代码失效,所以更新依赖要慎重。...既然都将nestjs更新了,那么nestjs相关生态的库自然也是要更新的,于是就遇到的typeorm 0.2.0 → 0.3.0用法的问题,主要是将findOne等方法改写,如 findOne(id)...整个过程还算顺利, 使用ApiFox编写接口文档与接口测试​ 在原项目中我Swagger写的其实够完善,但是在代码协同上只给前端一个Swagger地址不是很友好。...你可以访问 https://admin.kuizuo.cn/swagger-ui 来查看kz-admin的Swagger文档 json格式为https://admin.kuizuo.cn/swagger-ui...这里强烈建议将ApiFox接口问题,与nestjs的Swagger代码进行对比,就能体会到写好Swagger就能得到一份如此优雅的Api文档。 做前端和做后端看到这文档,这不得发自内心的赞美。

    2K10

    Nest.js 实战 (四):利用 Pipe 管道实现数据验证和转换

    它使用 class-validator 库来检查数据是否符合定义在 DTOs 或请求模型上的验证规则 ParseIntPipe:将字符串类型的参数转换为整数 ParseFloatPipe:将字符串类型的参数转换为浮点数...:将传入的值转换为枚举类型中的成员 DefaultValuePipe:如果传入的参数是 undefined 或 null,则使用默认值替换它 ParseFilePipe:用于处理上传的文件,它可以验证文件的类型...types.includes(metatype); } } 3、 main.ts 中全局注册: import { NestFactory } from '@nestjs/core'; import.../swagger'; import { IsNotEmpty, IsNumber, IsOptional, IsUUID } from 'class-validator'; export class.../common'; import { ApiOkResponse, ApiOperation, ApiTags } from '@nestjs/swagger'; // swagger 接口文档 import

    64710

    NestJS 7.x 折腾记: (5) 管道,一个好玩的东西!比如入参校验!

    前言 管道这个词,若是有玩过Linux的小伙伴肯定知晓,比如(看图): 意思就git的提交记录以单行显示的前三条,而且提交概要中有build这个词的 在nest里面的管道,主要是用来做入参数据类型的拦截转换...其实官方教程写的挺好了, 局部管道和全局管道都写到了, 这里我们以更具通用性的入参全局管道做例子, 尽量写的更贴近业务和更为粗俗的解释吧~ 安装 # class-validator: 提供非常丰富的类型装饰器...throw new BadRequestException(`字段校验不通过: ${msg}`); } return value; } // 这个函数的意义就是验证元数据传入的类型是否是定义内的常规类型数据.../swagger'; import { IsInt, IsNumberString, IsOptional, IsString, Max, Min, } from 'class-validator.../swagger'; import { CreateAppDto, FindOneParams, UserRole } from '.

    1.4K30

    NestJS、TypeORM 和 PostgreSQL 项目开发和数据库迁移完整示例(译)

    它是一个相当灵活的框架,建立在 Express.js 的基础上,可以让你在短时间内制作出 Node.js 服务,因为它集成了很多好功能(如完全的类型化支持、依赖注入、模块管理和更多)。...因此,您在代码中更改了实体类, typeORM 会为你自动同步字段, 但是,一旦您的数据库中有实际数据,后期打算修改字段类型或其他操作时,TypeORM 将通过删除并重新创建数据库表来更改数据库,这意味着你极有可能丢失了表内的数据...这就是一个简单的服务和响应 DTO 的样子: 注意:你必须为此安装 @nestjs/swagger、class-validator 和 class-transformer。...// item.dto.ts import { ApiModelProperty } from'@nestjs/swagger'; import { IsString, IsUUID, } from'class-validator...您只需安装: npm install --save @nestjs/swagger swagger-ui-express 并在 main.ts 中添加这几行 // main.ts asyncfunction

    7.6K21

    NestJS、TypeORM 和 PostgreSQL 项目开发和数据库迁移完整示例(译)

    它是一个相当灵活的框架,建立在 Express.js 的基础上,可以让你在短时间内制作出 Node.js 服务,因为它集成了很多好功能(如完全的类型化支持、依赖注入、模块管理和更多)。...因此,您在代码中更改了实体类, typeORM 会为你自动同步字段, 但是,一旦您的数据库中有实际数据,后期打算修改字段类型或其他操作时,TypeORM 将通过删除并重新创建数据库表来更改数据库,这意味着你极有可能丢失了表内的数据...这就是一个简单的服务和响应 DTO 的样子: 注意:你必须为此安装 @nestjs/swagger、class-validator 和 class-transformer。...// item.dto.ts import { ApiModelProperty } from'@nestjs/swagger'; import { IsString, IsUUID, } from'class-validator...您只需安装: npm install --save @nestjs/swagger swagger-ui-express 并在 main.ts 中添加这几行 // main.ts asyncfunction

    6K10
    领券