SearchAPI.site - MCP 服务器
该项目提供了一个模型上下文协议(MCP)服务器,通过SearchAPI.site将 AI 助手连接到外部数据源(Google、Bing 等)。
可用平台
- [x] Google - 网页搜索
- [x] Google - 图片搜索
- [x] Google - YouTube 搜索
- [ ] Google - 地图搜索
- [x] Bing - 网页搜索
- [ ] Bing - 图片搜索
- [ ] 红迪网
- [ ] X/推特
- [ ] Facebook 搜索
- [ ] Facebook 群组搜索
- [ ] 抖音
SearchAPI.site
- 网站
- API 文档
- Swagger UI 配置
- 在此处创建搜索 API 密钥
- GitHub
支持的传输
- [x] “stdio”传输 - CLI 使用的默认传输
- [x]“可流式传输 HTTP”传输 - 适用于基于 Web 的客户端
- [ ] 实现身份验证(“授权”标头带有
Bearer <token>
)
- [ ] 实现身份验证(“授权”标头带有
- [ ]
“sse”运输(已弃用) - [ ] 编写测试
如何使用
命令行界面
MCP 设置
对于使用 stdio 传输的本地配置:
对于远程 HTTP 配置:
HTTP 传输的环境变量:
您可以使用以下环境变量配置 HTTP 服务器:
MCP_HTTP_HOST
:绑定到的主机(默认值:127.0.0.1
)MCP_HTTP_PORT
:监听的端口(默认值:8080
)MCP_HTTP_PATH
:端点路径(默认值:/mcp
)
源代码概述
什么是 MCP?
模型上下文协议 (MCP) 是一种开放标准,允许 AI 系统安全且上下文地与外部工具和数据源连接。
该样板通过清晰的分层架构实现了 MCP 规范,可以扩展以构建任何 API 或数据源的自定义 MCP 服务器。
为什么要使用这个样板?
- 生产就绪架构:遵循已发布的 MCP 服务器中使用的相同模式,CLI、工具、控制器和服务之间有明确的分离。
- 类型安全:使用 TypeScript 构建,以改善开发人员体验、代码质量和可维护性。
- 工作示例:包括一个完全实现的 IP 查找工具,演示从 CLI 到 API 集成的完整模式。
- 测试框架:配备单元和 CLI 集成测试的测试基础设施,包括覆盖率报告。
- 开发工具:包括 ESLint、Prettier、TypeScript 和其他为 MCP 服务器开发预先配置的质量工具。
入门
先决条件
- Node.js (>=18.x):下载
- Git :用于版本控制
步骤 1:克隆并安装
第 2 步:运行开发服务器
使用 stdio 传输(默认)以开发模式启动服务器:
或者使用 Streamable HTTP 传输:
这将以热重载方式启动 MCP 服务器,并在http://localhost:5173启用 MCP 检查器。
⚙️ 代理服务器正在监听 6277 端口 🔍 MCP Inspector 已启动并运行于http://127.0.0.1:6274
当使用 HTTP 传输时,服务器默认在http://127.0.0.1:8080/mcp上可用。
步骤 3:测试示例工具
从 CLI 运行示例 IP 查找工具:
建筑学
该样板遵循清晰的分层架构模式,可分离关注点并提高可维护性。
项目结构
层次和职责
CLI 层( src/cli/*.cli.ts
)
- 目的:定义解析参数和调用控制器的命令行接口
- 命名:文件应命名为
<feature>.cli.ts
- 测试:
<feature>.cli.test.ts
中的 CLI 集成测试
工具层( src/tools/*.tool.ts
)
- 目的:为人工智能助手定义带有模式和描述的 MCP 工具
- 命名:文件应命名为
<feature>.tool.ts
,类型为<feature>.types.ts
- 模式:每个工具都应该使用 zod 进行参数验证
控制器层( src/controllers/*.controller.ts
)
- 目的:实现业务逻辑、处理错误和格式化响应
- 命名:文件应命名为
<feature>.controller.ts
- 模式:应返回标准化的
ControllerResponse
对象
服务层( src/services/*.service.ts
)
- 目的:与外部 API 或数据源交互
- 命名:文件应命名为
<feature>.service.ts
- 模式:纯 API 交互,逻辑最少
实用程序层 ( src/utils/*.util.ts
)
- 目的:提供跨应用程序的共享功能
- 主要用途:
logger.util.ts
:结构化日志记录error.util.ts
:错误处理和标准化formatter.util.ts
:Markdown 格式化助手
开发指南
开发脚本
测试
评估
evals 包会加载一个 mcp 客户端,然后运行 index.ts 文件,因此测试之间无需重新构建。您可以通过在 npx 命令前添加前缀来加载环境变量。完整文档可在此处找到。
代码质量
构建自定义工具
按照以下步骤将您自己的工具添加到服务器:
1.定义服务层
在src/services/
中创建一个新服务来与您的外部 API 交互:
2.创建控制器
在src/controllers/
中添加一个控制器来处理业务逻辑:
3. 实现MCP工具
在src/tools/
中创建工具定义:
4.添加CLI支持
在src/cli/
中创建 CLI 命令:
5. 注册组件
更新入口点以注册新组件:
调试工具
MCP 检查器
访问可视化 MCP 检查器来测试您的工具并查看请求/响应详细信息:
- 运行
npm run dev:server
- 在浏览器中打开http://localhost:5173
- 测试您的工具并直接在 UI 中查看日志
服务器日志
启用开发调试日志:
发布您的 MCP 服务器
准备发布您的自定义 MCP 服务器时:
- 使用您的详细信息更新 package.json
- 使用您的工具文档更新 README.md
- 构建项目:
npm run build
- 测试生产版本:
npm run start:server
- 发布到 npm:
npm publish
执照
**注意:**为了向后兼容,如果未找到searchapi
键,服务器也会识别完整软件包名称 ( searchapi-mcp-server
) 或未指定范围的软件包名称 ( searchapi-mcp-server
) 下的配置。不过,建议对新配置使用短searchapi
键。
hybrid server
The server is able to function both locally and remotely, depending on the configuration or use case.
Tools
通过 SearchAPI.site 将 AI 助手连接到外部数据源(Google、Bing 等),实现模型上下文协议 (MCP),以便安全、上下文地访问网络信息。
Related MCP Servers
- AsecurityAlicenseAqualityEnables AI assistants to interact with Meilisearch via the Model Context Protocol, allowing comprehensive index, document, and search management through a standardized interface.Last updated -684TypeScriptMIT License
- -securityFlicense-qualityImplements the Model Context Protocol (MCP) to provide AI models with a standardized interface for connecting to external data sources and tools like file systems, databases, or APIs.Last updated -90Python
- AsecurityFlicenseAqualityA Model Context Protocol server that enables AI assistants to perform real-time web searches, retrieving up-to-date information from the internet via a Crawler API.Last updated -1448JavaScript
- -securityAlicense-qualityA Model Context Protocol (MCP) based search API server that provides standardized access to Google Maps, Google Flights, Google Hotels and other services. This server enables AI assistants to access various search services through a unified interface.Last updated -48PythonMIT License