使用 OpenAPI 代理

GitBook 可以代理 测试它 请求,因此即使你的 API 服务器不支持 CORS,它们也能正常工作。

为什么会有这个功能

浏览器会阻止跨域请求,除非 API 服务器通过 CORS 标头明确允许。若未配置 CORS, 测试它 请求会在浏览器中失败。代理会通过 GitBook 在服务端转发这些请求,从而绕过这一限制。

为整个规范启用代理

添加 x-enable-proxy: true 到你的 OpenAPI 规范根部。

openapi: '3.0.3'
x-enable-proxy: true
info:
  title: Example API
  version: '1.0.0'
servers:
  - url: https://api.example.com

为特定操作启用或禁用

添加 x-enable-proxy 在某个操作上。

openapi: '3.0.3'
info:
  title: Example API
  version: '1.0.0'
servers:
  - url: https://api.example.com
paths:
  /reports:
    get:
      summary: List reports
      x-enable-proxy: true
      responses:
        '200':
          description: OK
    post:
      summary: Create report
      x-enable-proxy: false
      responses:
        '201':
          description: Created
circle-info

操作级别的设置 x-enable-proxy 优先于根级别的值。

代理支持什么

GitBook 会转发所有 HTTP 方法(GET, POST, PUT, DELETE, PATCH)、标头、Cookie 和请求体。

安全性

代理只会将请求转发到规范中 servers 数组里列出的 URL。它不能用于访问任意 URL。

circle-info

请确保你的 servers 数组包含所有你想要测试的基础 URL。如果某个 URL 没有列出, 测试它 发往该主机的请求将绕过代理。

最后更新于

这有帮助吗?