Claude Code MCP web search and fetch tools for third-party models.
Project description
CC Web MCP
CC Web MCP 是一个面向 Claude Code 第三方模型接入场景的轻量网页搜索和抓取 MCP。
它的主要用途是:当 Claude Code 接入 DeepSeek、Qwen、Kimi 等没有官方 WebSearch / WebFetch 能力的模型时,补上可访问国内外公开网页的只读工具链。官方 Claude 模型仍建议使用 Claude Code 原生搜索能力。
功能概览
web_search:按配置的搜索后端顺序搜索公开网页,默认duckduckgo -> bing_cn。fetch_url:抓取http/https页面并转为 Markdown,支持start_index分页读取。research_brief:先搜索,再抓取少量来源的短内容,减少上下文占用。health_check:检查依赖、配置和网络连通性。- 模型路由:通过
allowed_model_patterns、启动指令和 hook 守卫,让 DeepSeek、Qwen、Kimi 等第三方模型优先走 cc-web,官方 Claude 默认继续走原生WebSearch/WebFetch。 - 安全边界:默认禁止抓取本机、内网、链路本地地址和云 metadata 地址,并检查 DNS 解析和重定向后的最终 URL。
快速开始
开发目录中直接验证:
git clone https://github.com/JcDizzy/CC-Web-MCP.git <安装目录>
cd <安装目录>
py -3.11 -m pip install -e .
py -3.11 -m cc_web_mcp init
py -3.11 -m cc_web_mcp doctor
发布到 PyPI 后,推荐用 uvx 一次初始化:
uvx cc-web-mcp init --runner uvx
uvx cc-web-mcp doctor
如果之前已经用普通 pip、editable install 或旧的 uv 缓存路径初始化过,切换到 uvx 后请重新运行 uvx cc-web-mcp init --runner uvx --force,刷新 Claude Code 里保存的 MCP 命令路径。
cc-web-mcp init 是推荐的首次初始化入口。它会:
- 创建用户配置文件。
- 注册 Claude Code 用户级 stdio MCP。普通 Python 安装会注册为当前 Python 的
-m cc_web_mcp;--runner uvx会注册为uvx cc-web-mcp。 - 向用户级
~\.claude\CLAUDE.md写入第三方模型路由提示。 - 向用户级
~\.claude\settings.json合并 hook 守卫,并在写入前备份。
如果使用 pipx 或普通 pip 安装,也可以运行:
pipx install cc-web-mcp
cc-web-mcp init
cc-web-mcp doctor
如果 pip install 提示 cc-web-mcp.exe 所在目录不在 PATH,可以继续使用 py -3.11 -m cc_web_mcp ... 形式运行;初始化时注册到 Claude Code 的 MCP 命令会使用当前 Python 解释器和 -m cc_web_mcp,不依赖 cc-web-mcp.exe 是否在 PATH 中。
先看计划、不写文件:
cc-web-mcp init --dry-run
预览 uvx 注册命令:
uvx cc-web-mcp init --runner uvx --dry-run
如果只想初始化配置文件:
cc-web-mcp config init
cc-web-mcp config path
基础配置
默认配置路径:
- Windows:
%APPDATA%\cc-web-mcp\config.json - macOS/Linux:
~/.config/cc-web-mcp/config.json
常用调整:
- 同时适配更多第三方模型:
"allowed_model_patterns": ["deepseek", "qwen", "kimi"] - DuckDuckGo 不稳定时只使用 Bing 中文入口:
"search_providers": ["bing_cn"] - 某个第三方 API 的原生 Web 工具已经可用时:
"block_native_web_for_allowed_models": false - 明确允许官方 Claude 调用
cc-web fetch_url:"allow_fetch_url_for_claude": true
完整配置说明见 docs/configuration.md。
第一次验证建议
安装完成后,建议先用第三方模型在 Claude Code 里做一次小范围联网任务:
使用 cc-web 查询 “Claude Code MCP PreToolUse hook permissionDecision”,先用 research_brief 获取资料概览,再总结当前推荐写法。
如果模型仍尝试调用原生 WebSearch,先检查 ~\.claude\CLAUDE.md。如果模型尝试调用原生 WebFetch 并被拦截,说明 hook 已生效;模型应根据提示改用 cc-web fetch_url。
开发与测试
py -3.11 -m pip install -e .
py -3.11 -m pytest .\tests -q
构建发布包:
py -3.11 -m build
文档
重要边界
bing_cn是实用降级,不是全球搜索的等价替代。WebSearch在部分第三方 Anthropic-compatible API 中会在服务端直接报错,Claude Code 本地 hook 拦截不到;需要依赖CLAUDE.md启动指令提前绕开。- 当前不包含 Playwright 或浏览器自动化,不处理重 JavaScript、登录墙、验证码页面。
- 启用 Jina Reader fallback 时,目标 URL 会经过第三方服务;不要用于私密链接或内网页面。
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file cc_web_mcp-0.1.1.tar.gz.
File metadata
- Download URL: cc_web_mcp-0.1.1.tar.gz
- Upload date:
- Size: 46.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.13 {"installer":{"name":"uv","version":"0.11.13","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":null,"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9674eebc9e1a424d9552b3d76c611d6a6e6bb4e880f286bccecf3905530ee3b5
|
|
| MD5 |
d26a960ab0e6a2e3dbd489d312af76d8
|
|
| BLAKE2b-256 |
a1886ca28f87414b309dcd2e36f795a9beb751ec03369b852ef44eec20060492
|
File details
Details for the file cc_web_mcp-0.1.1-py3-none-any.whl.
File metadata
- Download URL: cc_web_mcp-0.1.1-py3-none-any.whl
- Upload date:
- Size: 33.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.13 {"installer":{"name":"uv","version":"0.11.13","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":null,"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a528a8518756a6176857111fb608e63a38ce3a14b1b959fe2b6a771ebcd0c845
|
|
| MD5 |
149f1587e7e0b173345a37b01f5419a8
|
|
| BLAKE2b-256 |
71482d5ab6196b14b3e985863c8b27bce111eab0dc7614caf7bb3d6790a0f58e
|