跳转到主要内容
要使用 Cloudflare 将文档托管在诸如 yoursite.com/docs 这样的子路径下,你必须创建并配置一个 Cloudflare Worker。
在开始之前,你需要一个 Cloudflare 账号和一个域名(可以在 Cloudflare 内或外进行管理)。

设置 Cloudflare Worker

如果你尚未创建,请按照 Cloudflare Workers 入门指南创建一个 Cloudflare Worker。
如果你的 DNS 提供商是 Cloudflare,请为该 CNAME 记录关闭代理,以避免潜在的配置问题。

使用 Vercel 部署时的代理

如果你在 Vercel 部署中使用 Cloudflare 作为代理,必须确保配置正确,以避免与 Vercel 的 domain 验证和 SSL 证书签发发生冲突。 错误的代理配置可能会阻止 Vercel 为 Let’s Encrypt SSL 证书进行签发,并导致 domain 验证失败。

必需的路径白名单

你的 Cloudflare Worker 必须允许以下特定路径的流量通过,且不能阻止或重定向:
  • /.well-known/acme-challenge/* - 用于 Let’s Encrypt 证书验证,必需
  • /.well-known/vercel/* - 用于 Vercel domain 验证,必需
虽然 Cloudflare 会自动处理许多验证规则,但创建额外的自定义规则可能会无意中拦截这些关键流量。

请求头转发要求

请确保在你的 Worker 配置中正确转发 HOST 请求头。若未正确转发请求头,验证请求将会失败。

配置路由

在你的 Cloudflare 控制台中,选择 Edit Code,然后将以下脚本添加到你的 Worker 代码中。有关编辑 Worker 的更多信息,请参阅 Cloudflare 文档
[SUBDOMAIN] 替换为你唯一的子域,将 [YOUR_DOMAIN] 替换为你网站的基础 URL;如果希望使用不同的子路径,则将 /docs 替换为你想要的子路径。
addEventListener("fetch", (event) => {
  event.respondWith(handleRequest(event.request));
});

async function handleRequest(request) {
  try {
    const urlObject = new URL(request.url);
    
    // 如果请求是 Vercel 验证路径,允许其通过
    if (urlObject.pathname.startsWith('/.well-known/')) {
      return await fetch(request);
    }
    
    // 如果请求是 docs 子路径
    if (/^\/docs/.test(urlObject.pathname)) {
      // 然后代理到 Mintlify
      const DOCS_URL = "[SUBDOMAIN].mintlify.dev";
      const CUSTOM_URL = "[YOUR_DOMAIN]";

      let url = new URL(request.url);
      url.hostname = DOCS_URL;

      let proxyRequest = new Request(url, request);

      proxyRequest.headers.set("Host", DOCS_URL);
      proxyRequest.headers.set("X-Forwarded-Host", CUSTOM_URL);
      proxyRequest.headers.set("X-Forwarded-Proto", "https");
      // 如果部署到 Vercel,保留客户端 IP
      proxyRequest.headers.set("CF-Connecting-IP", request.headers.get("CF-Connecting-IP"));

      return await fetch(proxyRequest);
    }
  } catch (error) {
    // 如果未找到操作,执行常规请求
    return await fetch(request);
  }
}
点击 Deploy,然后等待更改生效。
配置好 DNS(域名系统)后,自定义子域通常会在几分钟内生效。DNS 传播有时可能需要 1–4 小时,极少数情况下可达 48 小时。如果您的子域未能立即生效,请先耐心等待,再进行故障排查。

测试你的 Worker

在部署代码后,测试你的 Worker,确保它正确路由到你的 Mintlify 文档。
  1. 使用 Worker 的预览 URL 进行测试:your-worker.your-subdomain.workers.dev/docs
  2. 确认该 Worker 能正确路由到你的 Mintlify 文档和你的网站。

添加自定义 domain

  1. 在你的 Cloudflare 控制台中,进入你的 Worker。
  2. 前往 Settings > Domains & Routes > Add > Custom Domain
  3. 添加你的 domain。
我们建议同时添加带有 www. 和不带有 www. 的 domain。
有关更多信息,请参阅 Cloudflare 文档中的 Add a custom domain

解决 DNS 冲突

如果你的 domain 已经指向其他服务,你必须移除现有的 DNS 记录。你的 Cloudflare Worker 必须配置为接管该 domain 的全部流量。
  1. 删除该 domain 的现有 DNS 记录。更多信息请参阅 Cloudflare 文档:Delete DNS records
  2. 返回你的 Worker,添加你的自定义 domain。

Webflow 自定义路由

如果你使用 Webflow 托管主站点,并希望在同一 domain 的 /docs 路径下提供 Mintlify 文档,你需要通过 Cloudflare Workers 配置自定义路由,将所有非 docs 流量代理到你的主站点。
在部署此 Worker 之前,请确保你的主站点已配置为某个落地页,否则访问你主站点的访客会看到错误。
  1. 在 Webflow 中,为你的主站点设置一个落地页,例如 landing.yoursite.com。这是访客访问你的网站时首先看到的页面。
  2. 将你的主站点部署到该落地页。这样可以确保在你配置 Worker 的过程中,主站点依然可访问。
  3. 为避免冲突,将主站点中的任何绝对 URL 更新为相对路径。
  4. 在 Cloudflare 中选择 Edit Code,并将以下脚本添加到你的 Worker 代码中。
[SUBDOMAIN] 替换为你唯一的子域,将 [YOUR_DOMAIN] 替换为你网站的基础 URL,将 [LANDING_DOMAIN] 替换为你的落地页 URL,如有需要,将 /docs 替换为你想要的其他子路径。
  addEventListener("fetch", (event) => {
  event.respondWith(handleRequest(event.request));
  });
  async function handleRequest(request) {
  try {
    const urlObject = new URL(request.url);
    
    // 如果请求是 Vercel 验证路径,允许其通过
    if (urlObject.pathname.startsWith('/.well-known/')) {
      return await fetch(request);
    }
    
    // 如果请求是文档子路径
    if (/^\/docs/.test(urlObject.pathname)) {
      // 代理到 Mintlify
      const DOCS_URL = "[SUBDOMAIN].mintlify.dev";
      const CUSTOM_URL = "[YOUR_DOMAIN]";
      let url = new URL(request.url);
      url.hostname = DOCS_URL;
      let proxyRequest = new Request(url, request);
      proxyRequest.headers.set("Host", DOCS_URL);
      proxyRequest.headers.set("X-Forwarded-Host", CUSTOM_URL);
      proxyRequest.headers.set("X-Forwarded-Proto", "https");
      // 如果部署到 Vercel,保留客户端 IP
      proxyRequest.headers.set("CF-Connecting-IP", request.headers.get("CF-Connecting-IP"));
      return await fetch(proxyRequest);
    }
    // 将其他所有请求路由到主站点
    const MAIN_SITE_URL = "[LANDING_DOMAIN]";
    if (MAIN_SITE_URL && MAIN_SITE_URL !== "[LANDING_DOMAIN]") {
      let mainSiteUrl = new URL(request.url);
      mainSiteUrl.hostname = MAIN_SITE_URL;
      return await fetch(mainSiteUrl, {
        method: request.method,
        headers: request.headers,
        body: request.body
      });
    }
  } catch (error) {
    // 如果未找到匹配操作,处理常规请求
    return await fetch(request);
  }
  }
  1. 选择 Deploy,等待更改完成传播。
配置好 DNS(域名系统)后,自定义子域通常会在几分钟内生效。DNS 传播有时可能需要 1–4 小时,极少数情况下可达 48 小时。如果您的子域未能立即生效,请先耐心等待,再进行故障排查。