在Ubuntu上配置Swagger(现在通常指的是OpenAPI规范)通常涉及以下几个步骤:
sudo apt update
sudo apt install nodejs npm
sudo npm install -g swagger-jsdoc swagger-ui-express
swagger.json 的文件,这个文件将包含你的API规范。你可以手动编写这个文件,或者使用Swagger Editor来生成它。示例 swagger.json 文件:
{
"swagger": "2.0",
"info": {
"description": "My API",
"version": "1.0.0"
},
"basePath": "/api",
"paths": {
"/users": {
"get": {
"summary": "List all users",
"responses": {
"200": {
"description": "An array of users"
}
}
}
}
}
}
sudo npm install express
const express = require('express');
const swaggerUi = require('swagger-ui-express');
const swaggerDocument = require('./swagger.json');
const app = express();
app.use('/api-docs', swaggerUi.serve, swaggerUi.setup(swaggerDocument));
const port = process.env.PORT || 3000;
app.listen(port, () => {
console.log(`Server is running on port ${port}`);
});
Swagger UI提供了多种方式来自定义外观和行为。你可以通过传递选项给 swaggerUi.setup() 函数来自定义UI。例如,你可以更改UI的主题、布局和深度。
示例自定义Swagger UI:
const ui = swaggerUi.serve({
swaggerDocument: swaggerDocument,
deepLinking: true,
presets: [swaggerUi.presets.apis, swaggerUi.presets.promises],
plugins: [swaggerUi.plugins.DownloadUrl],
layout: "StandaloneLayout"
}, (req, res) => {
res.setHeader('Content-Type', 'text/html');
res.write(ui);
res.end();
});
app.use('/api-docs', ui);
使用npm启动你的应用:
node app.js
打开浏览器并访问 http://localhost:3000/api-docs,你应该能看到Swagger UI界面,其中包含了你的API文档。
以上步骤提供了一个基本的指南,具体的自定义选项和方法可能会随着Swagger工具的更新而变化。建议查看最新的Swagger文档和资源以获取最新信息。