溫馨提示×

swagger在ubuntu上的集成方法

小樊
48
2025-07-21 10:59:07
欄目: 智能運維

在Ubuntu上集成Swagger UI可以通過多種方法實現,以下是幾種常見的方法:

方法一:使用Docker

  1. 安裝Docker: 如果你還沒有安裝Docker,可以使用以下命令安裝:
sudo apt update
sudo apt install docker.io
  1. 拉取Swagger UI Docker鏡像
docker pull swaggerapi/swagger-ui-express
  1. 運行Swagger UI容器
docker run -p 8080:8080 swaggerapi/swagger-ui-express
  1. 訪問Swagger UI: 打開瀏覽器并訪問 http://localhost:8080,你應該能看到Swagger UI界面。

方法二:使用Node.js和Express

  1. 安裝Node.js和npm
sudo apt update
sudo apt install nodejs npm
  1. 創建一個新的Node.js項目
mkdir swagger-ui-project
cd swagger-ui-project
npm init -y
  1. 安裝Swagger UI Express
npm install swagger-ui-express
  1. 創建一個簡單的Express應用: 創建一個名為 app.js 的文件,并添加以下代碼:
const express = require('express');
const swaggerUi = require('swagger-ui-express');
const YAML = require('yamljs');

// Load Swagger document
const swaggerDocument = YAML.load('./swagger.yaml');
const app = express();

// Serve Swagger docs
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}`);
});
  1. 創建Swagger文檔: 創建一個名為 swagger.yaml 的文件,并添加你的API文檔。例如:
swagger: '2.0'
info:
  title: Sample API
  description: A sample API to demonstrate Swagger UI integration
  version: '1.0.0'
paths:
  /users:
    get:
      summary: List all users
      responses:
        '200':
          description: An array of users
          schema:
            type: array
            items:
              $ref: '#/definitions/User'
definitions:
  User:
    type: object
    properties:
      id:
        type: integer
        format: int64
      username:
        type: string
      firstName:
        type: string
      lastName:
        type: string
      email:
        type: string
        format: email
      password:
        type: string
        format: password
      phoneNumber:
        type: string
        format: phone
      active:
        type: boolean
        default: true
      dateCreated:
        type: string
        format: date-time
      updated:
        type: string
        format: date-time
      id:
        $ref: '#/definitions/User'
  1. 運行應用
node app.js
  1. 訪問Swagger UI: 打開瀏覽器并訪問 http://localhost:3000/api-docs,你應該能看到Swagger UI界面。

方法三:使用Snap包管理器

  1. 安裝Snap包管理器
sudo snap refresh
  1. 安裝Swagger UI
sudo snap install swagger-ui
  1. 啟動Swagger UI: 安裝完成后,可以通過以下命令啟動Swagger UI:
swagger-ui

這將在默認瀏覽器中打開Swagger UI界面。

方法四:使用npm全局安裝

  1. 安裝Node.js和npm(如果尚未安裝):
sudo apt update
sudo apt install nodejs npm
  1. 全局安裝Swagger UI
sudo npm install -g swagger-ui-express
  1. 創建一個簡單的Express應用并集成Swagger UI: 創建一個新的目錄并進入該目錄:
mkdir swagger-demo
cd swagger-demo

創建一個 index.js 文件,并添加以下內容:

const express = require('express');
const swaggerUi = require('swagger-ui-express');
const YAML = require('yamljs');

// Load Swagger document
const swaggerDocument = YAML.load('./swagger.yaml');
const app = express();

// Use swagger-ui-express middleware
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}`);
});
  1. 創建Swagger文檔文件: 創建一個 swagger.yaml 文件,并添加你的API文檔。例如:
swagger: '2.0'
info:
  title: Sample API
  description: This is a sample API documentation for Swagger.
  version: 1.0.0
host: localhost:8080
basePath: /api
schemes:
  - http
paths:
  /users:
    get:
      summary: Get list of users
      description: Returns a list of all users
      produces:
        - application/json
      responses:
        '200':
          description: A list of users
          schema:
            type: array
            items:
              $ref: '#/definitions/User'
definitions:
  User:
    type: object
    properties:
      id:
        type: integer
        format: int64
      username:
        type: string
      firstName:
        type: string
      lastName:
        type: string
      email:
        type: string
        format: email
      password:
        type: string
        format: password
      phoneNumber:
        type: string
        format: phone
      active:
        type: boolean
        default: true
      dateCreated:
        type: string
        format: date-time
      updated:
        type: string
        format: date-time
      id:
        $ref: '#/definitions/User'
  1. 啟動應用
node index.js
  1. 訪問Swagger UI: 在瀏覽器中訪問 http://localhost:3000/api-docs。

通過以上幾種方法,你可以在Ubuntu上成功集成Swagger UI,并查看和測試你的API文檔。選擇適合你的方法并按照步驟操作即可。

0
亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女