当前位置: 首页 > news >正文

Express中使用Swagger

Swagger


Swagger 是一种规范,用于描述 API 的结构,功能和参数。使用 Swagger 可以提供清晰的可视化 API 文档,可用于 API 交互的文档驱动开发,以及 API 的自动化测试和集成。

  1. 使用 npm 或 yarn 下载。
npm install swagger-jsdoc swagger-ui-express --save
yarn add swagger-jsdoc swagger-ui-express

  1. 在 Express 根目录下的 app.js 中导入。
const swaggerJsdoc = require('swagger-jsdoc');
const swaggerUi = require('swagger-ui-express');// ...// definition 字段用于定义 Swagger 规范,apis 字段用于指定使用 Swagger 规范的 API 文件路径
const options = {definition: {openapi: '3.0.0',info: {title: 'My API',version: '1.0.0'}},apis: ['./routes/*.js']
};const swaggerSpec = swaggerJsdoc(options);app.use('/api', swaggerUi.serve, swaggerUi.setup(swaggerSpec));// 其他路由...

  1. 导入后即可在 router 中新增 Swagger 注释。
/*** @swagger* /users:*  get:*    summary: 获取所有用户信息*    responses:*      200:*        description: 成功获取所有用户信息* *  post:*    summary: 创建用户*    parameters:*      - in: body*        name: user*        schema:*          type: object*          properties:*            name:*              type: string*            age:*              type: integer*    responses:*      200:*        description: 成功创建用户*/

如果编写接口时使用的是 ApiFoxPostCat 等支持导出 OpenAI 规范文件的接口工具,
可以导出 OpenAI 规范的接口文件,然后访问 Swagger Editor 并导入接口文件。将左侧显示的内容复制到 Express 的路由文件中,并调整格式如上文所示注释格式即可。

跳转 Express 下的 /api 即可访问所有使用 Swagger 规范的 API 接口。

http://www.lryc.cn/news/259690.html

相关文章:

  • 【C++】单一职责模式
  • GPT4-隐者地址
  • 教师考编需要什么条件
  • 刘家窑中医医院鲁卫星主任:冬季守护心脑血管,为社区居民送去健康关爱
  • 专家级定位咨询:打造不可复制的市场地位
  • 为什么说代码注释是程序员必备的技能?
  • 日期——年月日星期时间封装和年月日时间封装
  • RK3568全国产化多网口板卡带poe供电,支持鸿蒙麒麟系统
  • UI卡顿问题
  • Linux操作系统的ECS云服务器上搭建WordPress网站教程
  • 【Linux】多线程相关问题
  • GPS北斗卫星时空信号安全防护装置(授时)介绍
  • redis:一、面试题常见分类+缓存穿透的定义、解决方案、布隆过滤器的原理和误判现象、面试回答模板
  • 智慧公交:提高城市出行效率的数字化之路
  • Linux - 内存 - memblock 分配器
  • SQL、Jdbc、JdbcTemplate、Mybatics
  • 四六级高频词组8
  • fastapi-amis-admin快速创建一个后台管理系统增加音乐管理功能(3)
  • 全球化需要先搬离中国?中国公司出海不应失去“模式自信”
  • 三大维度解码剑南春“高质量发展”丨年度盘点
  • 外包干了3个月,技术退步明显.......
  • 思福迪运维安全管理系统 test_qrcode_b RCE漏洞复现
  • Salesforce×阿里云,影响几何?
  • Qt对excel操作
  • 每日一练 | 华为认证真题练习Day148
  • ES6学习(二):解构赋值
  • kubebuilder开发operator
  • docker中启动ES报错:AccessDeniedException: /usr/share/elasticsearch/data/nodes
  • java集成Nacos服务
  • 开源IPad Pro应用IDE:使用SSH远程连接服务器进行云端编程开发