web_search 工具使用你配置的提供商搜索网络,并返回结果。结果会按查询缓存 15 分钟(可配置)。
OpenClaw 还包含用于 X(原 Twitter)帖子的 x_search,以及用于轻量级 URL 获取的 web_fetch。在这个阶段,web_fetch 保持本地,而 web_search 和 x_search 可以在底层使用 xAI Responses。
web_search 是一个轻量级 HTTP 工具,不是浏览器自动化。对于 JS 重度依赖的网站或登录场景,请使用 Web Browser。对于获取特定 URL,请使用 Web Fetch。快速开始
选择提供商
Brave Search
结构化结果,带摘要。支持
llm-context 模式、国家/语言筛选。提供免费套餐。DuckDuckGo
无需密钥的回退方案。不需要 API 密钥。非官方的基于 HTML 的集成。
Exa
神经网络 + 关键词搜索,并提供内容提取(高亮、文本、摘要)。
Firecrawl
结构化结果。最适合与
firecrawl_search 和 firecrawl_scrape 搭配,用于深度提取。Gemini
通过 Google Search grounding 生成带引用的 AI 综合答案。
Grok
通过 xAI web grounding 生成带引用的 AI 综合答案。
Kimi
通过 Moonshot 网页搜索生成带引用的 AI 综合答案;未接地的聊天回退会明确失败。
MiniMax Search
通过 MiniMax Token Plan 搜索 API 提供结构化结果。
Ollama Web Search
通过已登录的本地 Ollama 主机或托管的 Ollama API 进行搜索。
Parallel
付费的 Parallel Search API(
PARALLEL_API_KEY);更高的速率限制和目标调优。Parallel Search (Free)
零配置默认方案。Parallel 的免费 Search MCP,提供为 LLM 优化的密集摘录且无需 API 密钥。
Perplexity
结构化结果,支持内容提取控制和域名过滤。
SearXNG
自托管元搜索。不需要 API 密钥。聚合 Google、Bing、DuckDuckGo 等。
Tavily
通过搜索深度、主题过滤,以及用于 URL 提取的
tavily_extract 提供结构化结果。提供商对比
| Provider | Result style | Filters | API key |
|---|---|---|---|
| Brave | Structured snippets | Country, language, time, llm-context mode | BRAVE_API_KEY |
| DuckDuckGo | Structured snippets | — | None (key-free) |
| Exa | Structured + extracted | Neural/keyword mode, date, content extraction | EXA_API_KEY |
| Firecrawl | Structured snippets | Via firecrawl_search tool | FIRECRAWL_API_KEY |
| Gemini | AI-synthesized + citations | — | GEMINI_API_KEY |
| Grok | AI-synthesized + citations | — | xAI OAuth, XAI_API_KEY, or plugins.entries.xai.config.webSearch.apiKey |
| Kimi | AI-synthesized + citations; fails on ungrounded chat fallbacks | — | KIMI_API_KEY / MOONSHOT_API_KEY |
| MiniMax Search | Structured snippets | Region (global / cn) | MINIMAX_CODE_PLAN_KEY / MINIMAX_CODING_API_KEY / MINIMAX_OAUTH_TOKEN |
| Ollama Web Search | Structured snippets | — | None for signed-in local hosts; OLLAMA_API_KEY for direct https://ollama.com search |
| Parallel | 密集摘录,按 LLM 上下文排序 | — | PARALLEL_API_KEY(付费) |
| Parallel Search (Free) | 密集摘录,按 LLM 上下文排序 | — | None (free Search MCP) |
| Perplexity | Structured snippets | Country, language, time, domains, content limits | PERPLEXITY_API_KEY / OPENROUTER_API_KEY |
| SearXNG | Structured snippets | Categories, language | None (self-hosted) |
| Tavily | Structured snippets | Via tavily_search tool | TAVILY_API_KEY |
自动检测
原生 OpenAI 网页搜索
当 OpenClaw 网页搜索已启用且未固定托管提供商时,直接使用 OpenAI Responses 模型会自动使用 OpenAI 托管的web_search 工具。这是捆绑的 OpenAI 插件中的提供商自有行为,仅适用于原生 OpenAI API 流量,不适用于 OpenAI 兼容的代理 base URL 或 Azure 路由。将 tools.web.search.provider 设置为其他提供商(例如 brave)可让 OpenAI 模型继续使用受管理的 web_search 工具;或者将 tools.web.search.enabled: false 设置为同时禁用受管理搜索和原生 OpenAI 搜索。
原生 Codex 网页搜索
支持 Codex 的模型可以选择使用提供商原生的 Responsesweb_search 工具,而不是 OpenClaw 托管的 web_search 函数。
- 在
tools.web.search.openaiCodex下进行配置 - 它仅对支持 Codex 的 OpenAI 模型生效(使用
api: "openai-chatgpt-responses"的openai/*模型) - 托管的
web_search仍然适用于非 Codex 模型 mode: "cached"是默认且推荐的设置tools.web.search.enabled: false会同时禁用托管搜索和原生搜索
web_search 行为。
网络安全
托管的web_search 提供商调用使用 OpenClaw 的受保护获取路径。对于受信任的提供商 API 主机,OpenClaw 仅允许该提供商主机名使用 Surge、Clash 和 sing-box 的 fake-IP DNS 应答,范围为 198.18.0.0/15 和 fc00::/7。其他私有、回环、链路本地和元数据目的地仍然会被阻止。
此自动允许不适用于任意 web_fetch URL。对于 web_fetch,仅当你的受信任代理拥有这些合成范围时,才显式启用 tools.web.fetch.ssrfPolicy.allowRfc2544BenchmarkRange 和 tools.web.fetch.ssrfPolicy.allowIpv6UniqueLocalRange。
设置网页搜索
文档和设置流程中的提供商列表按字母顺序排列。自动检测则使用单独的优先级顺序。 如果未设置provider,OpenClaw 会按以下顺序检查提供商,并使用第一个可用的提供商:
首先是基于 API 的提供商:
- Brave —
BRAVE_API_KEYorplugins.entries.brave.config.webSearch.apiKey(order 10) - MiniMax Search —
MINIMAX_CODE_PLAN_KEY/MINIMAX_CODING_API_KEY/MINIMAX_OAUTH_TOKEN/MINIMAX_API_KEYorplugins.entries.minimax.config.webSearch.apiKey(order 15) - Gemini —
plugins.entries.google.config.webSearch.apiKey,GEMINI_API_KEY, ormodels.providers.google.apiKey(order 20) - Grok — xAI OAuth,
XAI_API_KEY, orplugins.entries.xai.config.webSearch.apiKey(order 30) - Kimi —
KIMI_API_KEY/MOONSHOT_API_KEYorplugins.entries.moonshot.config.webSearch.apiKey(order 40) - Perplexity —
PERPLEXITY_API_KEY/OPENROUTER_API_KEYorplugins.entries.perplexity.config.webSearch.apiKey(order 50) - Firecrawl —
FIRECRAWL_API_KEYorplugins.entries.firecrawl.config.webSearch.apiKey(order 60) - Exa —
EXA_API_KEYorplugins.entries.exa.config.webSearch.apiKey; optionalplugins.entries.exa.config.webSearch.baseUrloverrides the Exa endpoint (order 65) - Tavily —
TAVILY_API_KEYorplugins.entries.tavily.config.webSearch.apiKey(order 70) - Parallel — 付费的 Parallel Search API,通过
PARALLEL_API_KEY或plugins.entries.parallel.config.webSearch.apiKey;可选的plugins.entries.parallel.config.webSearch.baseUrl会覆盖端点(order 75)
- Parallel Search (Free) — 零配置默认方案:可通过 Parallel 的免费托管 Search MCP 在没有账户或 API 密钥的情况下工作(order 76)
- DuckDuckGo — 无需密钥的 HTML 回退方案,不需要账户或 API 密钥(order 100)
- Ollama Web Search — 当你已通过
ollama signin登录且可访问时,可通过你配置的本地 Ollama 主机使用无需密钥的回退方案;当主机需要时可复用 Ollama 提供商的 bearer 认证,并且在配置了OLLAMA_API_KEY时可直接调用https://ollama.com搜索(order 110) - SearXNG —
SEARXNG_BASE_URLorplugins.entries.searxng.config.webSearch.baseUrl(order 200)
web_search 无需 API 密钥也能工作。
OpenAI Responses 模型是一个例外:当 tools.web.search.provider 未设置时,它们会使用 OpenAI 原生网页搜索,而不是上面的托管提供商。将 tools.web.search.provider 设置为 parallel-free(或其他提供商)即可让它们走托管路径。
所有提供商的密钥字段都支持 SecretRef 对象。位于
plugins.entries.<plugin>.config.webSearch.apiKey 下的插件作用域 SecretRef 会为内置的基于 API 的网页搜索提供商解析,包括 Brave、Exa、Firecrawl、Gemini、Grok、Kimi、MiniMax、Parallel、Perplexity 和 Tavily,无论提供商是通过 tools.web.search.provider 显式选择,还是通过自动检测选中。在自动检测模式下,OpenClaw 只会解析被选中的提供商密钥——未选中的 SecretRef 保持非激活状态,因此你可以配置多个提供商而无需为未使用的那些支付解析成本。配置
plugins.entries.<plugin>.config.webSearch.* 下。Gemini 还可以在其专用网页搜索配置和 GEMINI_API_KEY 之后,
将 models.providers.google.apiKey 和 models.providers.google.baseUrl 作为优先级较低的
回退项复用。示例请参见各提供商页面。
Grok 还可以复用通过 openclaw models auth login --provider xai --method oauth 获取的 xAI OAuth 认证配置文件;API 密钥配置仍然是回退方案。
tools.web.search.provider 会根据已捆绑和已安装插件清单中声明的网页搜索提供商 ID 进行验证。像 "brvae" 这样的拼写错误会导致配置验证失败,而不是静默回退到自动检测。如果某个已配置提供商只有过时的插件证据,例如卸载第三方插件后留下的
plugins.entries.<plugin> 配置块,
OpenClaw 会保持启动过程的弹性并报告警告,以便你重新安装该
插件或运行 openclaw doctor --fix 清理过时配置。
web_fetch 备用提供商的选择是独立的:
- 通过
tools.web.fetch.provider选择 - 或省略该字段,让 OpenClaw 从可用凭据中自动检测第一个就绪的 web-fetch 提供商
- 非沙箱化的
web_fetch可使用声明了contracts.webFetchProviders的已安装插件提供商;沙箱化获取仍仅限捆绑提供商 - 目前捆绑的 web-fetch 提供商是 Firecrawl,在
plugins.entries.firecrawl.config.webFetch.*下配置
openclaw onboard 或
openclaw configure --section web 期间选择 Kimi 时,OpenClaw 还可能会询问:
- Moonshot API 区域(
https://api.moonshot.ai/v1或https://api.moonshot.cn/v1) - 默认的 Kimi 网页搜索模型(默认为
kimi-k2.6)
x_search 时,请配置 plugins.entries.xai.config.xSearch.*。它使用
与聊天相同的 xAI 认证配置文件,或 Grok 网页搜索使用的 XAI_API_KEY / 插件网页搜索
凭据。
旧版 tools.web.x_search.* 配置会由 openclaw doctor --fix 自动迁移。
当你在 openclaw onboard 或 openclaw configure --section web 中选择 Grok 时,
OpenClaw 还可以提供可选的 x_search 设置,并使用相同的凭据。
这是 Grok 路径中的一个单独后续步骤,不是另一个顶层
网页搜索提供商选择。如果你选择其他提供商,OpenClaw 不会
显示 x_search 提示。
存储 API 密钥
- 配置文件
- 环境变量
运行
openclaw configure --section web 或直接设置密钥:工具参数
| 参数 | 描述 |
|---|---|
query | 搜索查询(必填) |
count | 返回结果数(1-10,默认:5) |
country | 2 字母 ISO 国家代码(例如 “US”、“DE”) |
language | ISO 639-1 语言代码(例如 “en”、“de”) |
search_lang | 搜索语言代码(仅 Brave) |
freshness | 时间筛选:day、week、month 或 year |
date_after | 此日期之后的结果(YYYY-MM-DD) |
date_before | 此日期之前的结果(YYYY-MM-DD) |
ui_lang | UI 语言代码(仅 Brave) |
domain_filter | 域名允许/拒绝列表数组(仅 Perplexity) |
max_tokens | 总内容预算,默认 25000(仅 Perplexity) |
max_tokens_per_page | 每页 token 限制,默认 2048(仅 Perplexity) |
x_search
x_search 使用 xAI 查询 X(原 Twitter)帖子,并返回
带有引文的 AI 综合答案。它接受自然语言查询和
可选的结构化过滤器。OpenClaw 仅在提供此工具调用的请求上启用内置的 xAI x_search
工具。
xAI 将
x_search 文档化为支持关键词搜索、语义搜索、用户
搜索以及线程抓取。对于每个帖子的互动统计信息,例如转发、回复、
收藏或浏览,建议优先针对精确的帖子 URL 或状态 ID 进行定向查询。
广泛的关键词搜索可能会找到正确的帖子,但返回的单帖元数据可能
不够完整。一个好的模式是:先定位帖子,然后
再运行第二个聚焦于该精确帖子的 x_search 查询。x_search 配置
plugins.entries.xai.config.xSearch.baseUrl 已设置时,x_search 会向 <baseUrl>/responses 发起 POST 请求。如果省略该字段,则回退到 plugins.entries.xai.config.webSearch.baseUrl,然后是旧版 tools.web.search.grok.baseUrl,最后是公共 xAI 端点。
x_search 参数
| 参数 | 描述 |
|---|---|
query | 搜索查询(必填) |
allowed_x_handles | 将结果限制为特定的 X 账号 |
excluded_x_handles | 排除特定的 X 账号 |
from_date | 仅包含此日期及之后的帖子(YYYY-MM-DD) |
to_date | 仅包含此日期及之前的帖子(YYYY-MM-DD) |
enable_image_understanding | 允许 xAI 检查匹配帖子中附带的图片 |
enable_video_understanding | 允许 xAI 检查匹配帖子中附带的视频 |
x_search 示例
示例
工具配置文件
如果你使用工具配置文件或允许列表,请添加web_search、x_search 或 group:web:
相关内容
- Web Fetch — 获取 URL 并提取可读内容
- Web Browser — 针对 JS 密集型网站的完整浏览器自动化
- Grok Search — 将 Grok 作为
web_search提供商 - Ollama Web Search — 通过你的 Ollama 主机进行免密钥网页搜索