Golang 自动生成swagger
-
安装
go get -u github.com/swaggo/swag/cmd/swag
-
在项目下执行
swag init
,会生成docs目录。如果目录存在则会报错。 - docs目录下会生成docs.go,swagger.json和swagger.yaml,根据需求使用。
Gin 集成例
- main.go
// @title Sample Service API // @version 1.0 // @description Platform API for Sample. // @contact.name getsu // @contact.url http://www.swagger.io/support // @contact.email acrhwfy@gmail.com // @license.name Apache 2.0 // @license.url http://www.apache.org/licenses/LICENSE-2.0.html // @host sample.com // @BasePath /api // @securityDefinitions.apikey ApiKeyAuth // @in header // @name Authorization func setupRouter() *gin.Engine { r := gin.Default() r.Run() }
- Controller.go
//CreateApp create app // CreateApp godoc // @Summary create app // @Description create app // @Accept json // @Produce json // @Param app body dao.App true "create app" // @Success 200 {object} App // @Failure 400 {object} Response // @Failure 500 {object} Response // @Router /app [post] // @Security ApiKeyAuth func CreateApp(c *gin.Context) { //略 }
NodeJS 自动生成swagger
Express框架集成
- 安装
npm i express-swagger-generator --save-dev
- 代码例:
- main.js
var express = require('express'); var bodyParser = require('body-parser'); var controller = require('./controller'); const config = require('./config/config'); var app = express(); app.use(bodyParser.json()); app.use(bodyParser.urlencoded({ extended: true })); const expressSwagger = require('express-swagger-generator')(app); let options = { swaggerDefinition: { info: { description: 'This is a sample server', title: 'Swagger', version: '1.0.0', }, host: 'localhost:3000', basePath: '/v1', produces: [ "application/json", "application/xml" ], schemes: ['http', 'https'], securityDefinitions: { JWT: { type: 'apiKey', in: 'header', name: 'Authorization', description: "", } } }, route: { url:'/swagger', docs:'/swagger.json', //swagger文件 api }, basedir: __dirname, //app absolute path files: ['./controller/*.js'] //Path to the API handle folder }; expressSwagger(options) app.listen(config.port);
- controller/api.js
/** * api for get request * @route GET /api/run * @returns {object} 200 - An array of user info * @returns {Error} default - Unexpected error */ exports.doGet = function(req, res) { res.setHeader('Content-Type', 'application/json;charset=utf-8'); res.send({ result: true, message: 'ok' }); }; /** * api for post request * @route POST /api/run * @returns {object} 200 - An array of user info * @returns {Error} default - Unexpected error */ exports.doPost = function(req, res) { res.setHeader('Content-Type', 'application/json;charset=utf-8'); res.send({ result: true, message: 'ok' }); };
NestJS 集成
- 安装
npm i --save @nestjs/swagger
During the examination of the defined controllers, the SwaggerModule is looking for all used @Body(), @Query(), and @Param() decorators in the route handlers.
import { NestFactory } from '@nestjs/core'; import { SwaggerModule, DocumentBuilder } from '@nestjs/swagger'; import { ApplicationModule } from './app.module'; async function bootstrap() { const app = await NestFactory.create(ApplicationModule); const options = new DocumentBuilder() .setTitle('Cats example') .setDescription('The cats API description') .setVersion('1.0') .addTag('cats') .build(); const document = SwaggerModule.createDocument(app, options); SwaggerModule.setup('api', app, document); await app.listen(3001); } bootstrap();
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- 数据生成工具 ZenData 发布 2.0 版本,自动生成“互联网黑话”!
- 自动生成高效DNN,适用于边缘设备的生成合成工具FermiNets
- Simulink自动生成代码
- changelog 日志自动生成插件
- 深度有趣 | 23 歌词古诗自动生成
- 自定义Mybatis自动生成代码规则
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
算法设计与实验题解
王晓东 / 电子工业 / 2006-9 / 46.00元
《算法设计与实验题解》是与普通高等教育“十一五”国家级规划教材《计算机算法设计与分析》(第2版)配套的辅助教材,对主教材中的全部习题做了解答或给出了解题思路提示,并对主教材的内容进行了扩展,有些主教材中无法讲述的较深入的主题以习题的形式展现出来。为了提高学生解决实际问题的能力,《算法设计与实验题解》还将主教材中的许多习题改造成算法实现题,要求学生设计出算法并上机实现。作者还结合精品课程建设,进行了......一起来看看 《算法设计与实验题解》 这本书的介绍吧!