首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

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

、统一的结构,用于跨各种描述语言和序列化格式描述 APINest 集成 Swagger 1、 安装依赖pnpm add @nestjs/swagger swagger-ui-express 2、 在 main.ts...} from '@nestjs/swagger';import { AppModule } from '....: number;} 2、 在 Controller 控制器 中使用装饰器import { Controller, Get, Query } from '@nestjs/common';import {...装饰器装饰器描述@ApiTags为控制器或方法添加标签,用于组织 Swagger UI 文档@ApiOperation为控制器方法添加操作描述,包括摘要和详细描述@ApiParam描述路径参数、请求参数或响应参数...Token,用于身份验证@ApiProperty为 DTO 类型的属性添加元数据,如描述、默认值等@ApiQuery描述查询参数,包括名称、类型、描述等@ApiHeader描述请求头信息,包括名称、类型

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

    学完这篇 Nest.js 实战,还没入门的来锤我!(长文预警)

    要创建新的Nest.js 应用程序,请在终端上运行以下命令: npm i -g @nestjs/cli // 全局安装Nest nest new project-name // 创建项目 执行完创建项目...确实AngularJS、Spring和Nest.js都是基于控制反转原则设计的,而且都使用了依赖注入的方式来解决解耦问题。如果你觉得一头雾水, 别急,这些问题后面深入学习都会一一讲解的。...说心里话, 使用体验一般般,只能说还行 首先安装一下: npm install @nestjs/swagger swagger-ui-express -S 我这里安装的版本是:5.1.4, 和4.x.x...接下来需要在main.ts中设置Swagger文档信息: ... import { SwaggerModule, DocumentBuilder } from '@nestjs/swagger'; async...接口直接报500了, 因为我们实体定义的author字段不能为空的,所有在写入数据时报错了。这样体验非常不好, 很可能前端就怀疑我们接口写错了,所有我们应该对异常进行一定的处理。

    14.6K65

    学完这篇 Nest.js 实战,还没入门的来锤我!(长文预警)

    要创建新的Nest.js 应用程序,请在终端上运行以下命令: npm i -g @nestjs/cli // 全局安装Nest nest new project-name // 创建项目 复制代码...确实AngularJS、Spring和Nest.js都是基于控制反转原则设计的,而且都使用了依赖注入的方式来解决解耦问题。如果你觉得一头雾水, 别急,这些问题后面深入学习都会一一讲解的。...说心里话, 使用体验一般般,只能说还行 首先安装一下: npm install @nestjs/swagger swagger-ui-express -S 复制代码 我这里安装的版本是:5.1.4, 和...接下来需要在main.ts中设置Swagger文档信息: ... import { SwaggerModule, DocumentBuilder } from '@nestjs/swagger'; async...接口直接报500了, 因为我们实体定义的author字段不能为空的,所有在写入数据时报错了。这样体验非常不好, 很可能前端就怀疑我们接口写错了,所有我们应该对异常进行一定的处理。

    10.5K11

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

    在 Nest.js 中,管道(Pipelines) 是一种强大的功能,用于预处理进入控制器方法的请求数据,如请求体、查询参数、路径参数等。...,管道可以抛出异常,从而阻止请求的进一步处理,并向客户端返回适当的错误信息一致性:管道有助于在整个应用中保持一致性,避免在不同的控制器或方法中重复相同的预处理逻辑可插拔性和重用性:管道是可插拔的组件,可以很容易地在多个控制器或方法之间共享和重用内置管道...types.includes(metatype); } } 3、 main.ts 中全局注册: import { NestFactory } from '@nestjs/core'; import...,它的 DTO 如下:import { ApiProperty } from '@nestjs/swagger';import { IsNotEmpty, IsNumber, IsOptional, IsUUID...from '@nestjs/common';import { ApiOkResponse, ApiOperation, ApiTags } from '@nestjs/swagger'; // swagger

    20710

    NestJS 7.x 折腾记: (4) Swagger接入及相关用法

    前言 swagger这东东,萝卜青菜各有所爱吧. 反正我呆的公司用这个,我用的也还行! 有兴趣的可以瞅瞅~ 说说优点吧, 可以精确的展示每个字段意义,只要注解写的到位! schema也能正常读取!...的nest module,官方团队维护的 # 后者是适配express的swagger ui库 # 库用新不用旧,语法会有所差异!...yarn add @nestjs/swagger swagger-ui-express 配置 抽离的环境变量(dev.local.env) # ------- Node服务相关 ------------..., // 接口聚合前缀,在nest用全局prefix,但是丢给swagger定义也不冲突 }), ); 代码入口(main.ts) 熟悉的味道,还是把一些配置抽里成环境变量, 外部维护,通过注册中心使用...: any[]; } import { ApiProperty, ApiPropertyOptional } from '@nestjs/swagger'; export enum UserRole

    1.7K10

    快速打开 Nestjs 的世界

    应用中模块间的关系将由@Module()装饰器中携带的所有元数据描述。...图片来自:docs.nestjs.com/controllers 控制器用来接收和处理客户端发起的特定请求,不同的客户端请求将由 Nestjs 路由机制分配到对应的控制器进行处理。...读取请求对象 请求对象表示一个 HTTP 请求所携带的数据信息,如请求数据中的查询参数、路由参数、请求头、请求体等数据。...学习异常过滤器的使用 图片来自:docs.nestjs.com/exception-f… 异常层由开箱即用的全局异常过滤器还行,负责处理应用程序中所有未处理的异常。...服务的使用:封装复杂的业务逻辑,并提供此能力给其它模块; 模块的使用:负责项目所有控制器、提供者的管理工作; 中间件的使用:更改请求响应对象和执行下一个中间件; 异常过滤器的使用:处理项目所有未处理的异常

    55910

    Node.js服务端开发教程 (三):NestJS的路由与控制器

    其实,每一个URL都是由网站的服务器端程序来接收并进行处理,最终定向到相应的资源。这种机制,在服务端程序中被称作路由。 ? 路由机制决定了请求与控制器之间的关系,即一个请求被分派到哪个控制器进行处理。...NestJS框架中定义了若干个专门用于路由处理相关的装饰器,通过它们,可以非常容易的将普通的class类装饰成一个个路由控制器。...路径数组 // 可匹配到的访问路径:匹配上面1和2里的所有路径 @Get(["greeting", "say_*"]) // 4....三、@Headers和@Header - 获取请求头和设置响应头 我们经常会使用HTTP头来在客户端和服务端传递信息,比如:通过请求头来携带登录授权的Authorization令牌值;或者为响应头设置Access-Control-Allow-Origin...在NestJS中我们可以通过装饰器来很方便的实现对请求头的访问和操作: @Post("test") @Header('x-my-resp', '123') test(@Headers("x-my-val

    3.6K20

    nest.js 添加 swagger 响应数据文档

    基本使用​ 通常情况下,在 nest.js 的 swagger 页面文档中的响应数据文档默认如下 此时要为这个控制器添加响应数据文档的话,只需要先声明 数据的类型,然后通过@ApiResponse...装饰器添加到该控制器上即可,举例说明 todo.entity.ts @Entity('todo') export class TodoEntity { @Column() @ApiProperty.../common' import { ApiExtraModels, ApiResponse, getSchemaPath } from '@nestjs/swagger' import { ResOp...由于有些类没有被任何控制器直接引用, SwaggerModule SwaggerModule 还无法生成相应的模型定义,所以需要 @ApiExtraModels(model) 将其额外导入。...不过我还对其进行扩展,使其能够返回分页数据格式,具体根据实际数据而定,演示效果如下图: 导入第三方接口管理工具​ 通过上述的操作后,此时记下项目的 swagger-ui 地址,例如 http://127.0.0.1

    39520

    五分钟带你入门基于Nodejs的强大的Web框架— NestJS

    语义化翻译就是 控制器,它负责处理传入的请求并将响应结果返回给客户端。 在 Nest 中,控制器和路由机制是结合在一起的,控制器的目的是接收应用程序的特定请求。其路由机制控制哪个控制器接收哪些请求。...通常,每个控制器都有多个路由,不同的路由可以执行不同的操作。...语义化翻译就是 提供者,在 Nest 中,除了控制器以外,几乎所有的东西都可以被视为提供者,比如service、repository、factory、helper等等。...针对这种特殊情况,Nest 提供了一个很强大的功能 —— 全局模块,全局模块一旦被导入到根模块,在其他所有模块中即可轻松的使用这个全局模块导出的提供者,而且也不用在其他模块导入这个全局模块。...在 Nest 中,中间件可以有多个,他们之间使用 next() 方法作为连接,连接后的所有中间件将在整个请求-响应周期内通过 next()依次执行。

    2.9K20

    Nest集成Swagger并部署至YAPI

    集成Swagger 首先,我们通过yarn安装三个依赖包,如下所示: yarn add @nestjs/swagger swagger-ui-express fastify-swagger 安装完成后...,我们打开项目的入口文件main.ts添加如下所示的代码: import { DocumentBuilder, SwaggerModule } from "@nestjs/swagger"; async...: default选项列出了我们项目中的所有接口 image-20220317211550995 通过注解编写接口文档 在@nestjs/swagger库中,它提供了丰富的依赖供我们使用, 为我们生成友好的接口文档...-20220317224923516 ❝有关swagger注解的更多使用方法请移步:OpenAPI (Swagger)[4] 部署至服务器 接下来,我们要做的就是将项目打包部署到服务器了,本项目采用的是单文件构建法...经过一番思考后,应该是因为webpack把所有依赖都打包进main.js了,swagger-ui引用的文件应该是相对路径的,所以才导致了404问题,抱着这个疑问,我打开了swagger-ui-express

    2K40

    【Nest教程】Nest项目集成JWT接口认证

    Json web token (JWT), 是为了在网络应用环境间传递声明而执行的一种基于JSON的开放标准((RFC 7519).该token被设计为紧凑且安全的,特别适用于分布式站点的单点登录(SSO...JWT的声明一般被用来在身份提供者和服务提供者间传递被认证的用户身份信息,以便于从资源服务器获取资源,也可以增加一些额外的其它业务逻辑所必须的声明信息,该token也可直接被用于认证,也可被加密。...我们都知道,http协议本身是无状态的协议,如果在一个系统中,我们只有登录后在可以操作,由于http是无状态的,所以那就必须每个接口都需要一个认证,来查看当前用户是否有权限。...今天我们就基于之前的项目,集成JWT。 1 user.service方法 增加一个查询单个用户的方法,这个方法不需要对应控制器。...,我们接下来写逻辑 import { ApiTags, ApiParam, ApiQuery, ApiHeader } from '@nestjs/swagger'; import { Controller

    3K1311
    领券