比 Swagger-UI 更好用、更美观的 OpenAPI-UI 接口文档,可以快速的生成模拟请求参数并调用 API 请求,也是简化版的 postman 工具
- CN: www.openapi-ui.com,支持http、https
- US: doc.openapi-ui.com
- US2: docs.openapi-ui.com
<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<title>openAPI UI</title>
</head>
<body>
<div id="openapi-ui-container" spec-url="https://petstore3.swagger.io/api/v3/openapi.json" theme="light"></div>
<script src="https://cdn.jsdelivr.net/npm/openapi-ui-dist@latest/lib/openapi-ui.umd.js"></script>
</body>
</html>
import { useEffect } from "react";
const SetUpOpenApiUI = () => {
useEffect(() => {
import("openapi-ui-dist")
}, []);
return (
<div id="openapi-ui-container" spec-url="https://petstore3.swagger.io/api/v3/openapi.json" theme="light" />
);
}
export const openapiRoutes = {
path: "/openapi",
id: "openapi",
element: <SetUpOpenApiUI />,
};
# node version >= 18
# 下载依赖包
pnpm install
# or make install
# 启动
npm run dev
# or make dev
# 打包构建
npm run build
# or make build
# 生成docker镜像
make docker-build
# 运行docker镜像
make docker-run
# 生成docker镜像,并且运行docker镜像
make docker-build-run
- swagger2.json/swagger2.yml
- openapi3.json/openapi3.yml
- 输入 swagger2/openapi3 的网关地址, 重新刷新页面就可以更新接口
- 上传 swagger2/openapi3 文件
- 输入 swagger2/openapi3 文本
- 支持配置接口请求超时时间,默认的接口请求超时时间为 2 分钟
- 支持配置接口请求Authorization,可以在当前接口覆写Authorization
- 只有通过 url 模式导入才可以分享链接
- 拷贝链接分享给需要的人,他们可以通过 url 回显到指定接口
- 如果 openapi 接口请求参数 schema 定义了 format 字段,则使用 openapi-sampler 去生成模拟请求参数
- 如果 openapi 接口请求参数 schema 没有定义 format 字段, 则使用 faker 去生成模拟请求参数
- 如果返回的结构体含有 message 字段,则展示 message 字段
- 如果返回的结构体含有 msg 字段,则展示 msg 字段
- 如果返回的结果是字符串,则展示字符串
- 展示 AxiosResponse.statusText 类型对应的字段
- 展示 AxiosError.message 类型对应的字段
- 如果不能连接内网api, 你可以在本地运行此项目或者使用 docker 在本地或者服务器部署此项目
- 默认的缓存策略是session storage, 可以同时打开多个页面去查看多个 api 网关
# 拉取 Docker 镜像
docker pull ghcr.io/rookie-luochao/openapi-ui:latest
# 启动容器,nginx反向代理可自定义端口,例如:docker run -d -p 8081:80 ghcr.io/rookie-luochao/openapi-ui:latest
docker run -d -p 80:80 -e APP_CONFIG=env=zh,appNameZH=简洁美观的接口文档 ghcr.io/rookie-luochao/openapi-ui:latest
node >= 18