data-process-mcp
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@data-process-mcpMatch this JSON against the OpenAPI spec"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
ICBC MCP 示例项目
基于 Model Context Protocol (MCP) 的 Streamable HTTP Transport 示例,使用 Node.js + TypeScript 实现。该示例演示如何通过 HTTP 端点暴露 MCP 工具,供 MCP 客户端(如 Claude Desktop、Cursor 等)调用。
项目结构
icbc_mcp/
├── src/
│ ├── index.ts // 入口文件
│ ├── server.ts // HTTP 服务器 + MCP 端点
│ ├── client.ts // MCP 测试客户端
│ └── tools.ts // MCP 工具定义
├── package.json // 依赖与脚本
├── tsconfig.json // TypeScript 配置
└── README.md // 本文件Related MCP server: MCP-OpenAPI
快速开始
1. 安装依赖
cd E:\work\icbc_mcp
npm install2. 开发模式运行
npm run dev服务器将在 http://localhost:3000 启动。
3. 生产模式
npm run build # 编译 TypeScript
npm start # 运行编译后的 JS可用端点
MCP 主端点
POST
http://localhost:3000/mcp
MCP JSON-RPC 2.0 请求入口,客户端通过此端点调用工具。GET
http://localhost:3000/mcp
SSE(Server-Sent Events)端点,用于服务器主动推送(可选)。
健康检查
GET
http://localhost:3000/health
返回服务器状态。
已实现的 MCP 工具
工具名 | 描述 | 参数 |
| OpenAPI 接口匹配器 |
|
Streamable HTTP Transport 说明
本示例采用 Streamable HTTP Transport,这是 MCP 协议定义的一种传输方式:
客户端连接流程:
POST
/mcp发送initialize请求,建立会话POST
/mcp发送notifications/initialized通知POST
/mcp发送tools/list获取可用工具POST
/mcp发送tools/call调用具体工具
无状态设计:
每个 HTTP 请求创建一个独立的 transport 实例
适合负载均衡、无状态部署场景
SSE 支持:
GET
/mcp提供 SSE 端点,用于服务端主动推送(如资源变更通知)
客户端配置示例
Claude Desktop 配置
在 Claude Desktop 的 claude_desktop_config.json 中添加:
{
"mcpServers": {
"icbc-mcp-demo": {
"command": "node",
"args": ["E:\\work\\icbc_mcp\\dist\\index.js"],
"env": {
"PORT": "3000"
}
}
}
}直接 HTTP 调用示例
# 初始化
curl -X POST http://localhost:3000/mcp \
-H "Content-Type: application/json" \
-d '{
"jsonrpc": "2.0",
"id": 1,
"method": "initialize",
"params": {
"protocolVersion": "2024-11-05",
"clientInfo": {
"name": "curl-client",
"version": "1.0.0"
}
}
}'
# 调用 match_openapi_interfaces 工具
curl -X POST http://localhost:3000/mcp \
-H "Content-Type: application/json" \
-d '{
"jsonrpc": "2.0",
"id": 2,
"method": "tools/call",
"params": {
"name": "match_openapi_interfaces",
"arguments": {
"match_json": "{}",
"openapi_doc": "{}"
}
}
}'Client 使用手册
本项目内置了一个命令行 MCP 客户端,可直接连接本地或远程 MCP 服务端进行测试。
1. 启动服务端
先启动 MCP 服务端:
npm run dev或者:
npm run build
npm start默认服务端地址为 http://localhost:3000/mcp。
2. 启动客户端
使用默认地址连接:
npm run client连接指定地址:
npm run client -- http://localhost:3000/mcp也可以通过环境变量指定地址:
$env:MCP_SERVER_URL="http://localhost:3000/mcp"
npm run client3. 交互模式命令
客户端启动后会进入交互模式,支持以下命令:
命令 | 说明 |
| 查看帮助信息 |
| 列出服务端当前暴露的所有工具 |
| 测试客户端是否成功连通 MCP 服务端 |
| 调用指定工具 |
| 退出客户端 |
示例:
call match_openapi_interfaces {"match_json":"{}","openapi_doc":"{}"}4. 非交互模式
如果只想快速测试,也可以直接使用命令模式。
列出工具:
npm run client -- list调用 match_openapi_interfaces:
npm run client -- call match_openapi_interfaces "{\"match_json\":\"{}\",\"openapi_doc\":\"{}\"}"连接指定服务端后再列出工具:
npm run client -- http://localhost:3000/mcp list5. 参数格式说明
call命令中的参数必须是合法的 JSON 对象JSON 最外层必须是
{},不能直接传数组或普通字符串如果工具没有参数,可以直接传空对象
{}
正确示例:
npm run client -- call match_openapi_interfaces "{\"match_json\":\"{}\",\"openapi_doc\":\"{}\"}"错误示例:
npm run client -- call match_openapi_interfaces "hello"6. 推荐测试流程
启动服务端
执行
npm run client -- list,确认客户端能成功连接并拿到工具列表执行
npm run client -- call match_openapi_interfaces "{\"match_json\":\"{}\",\"openapi_doc\":\"{}\"}",确认工具调用正常执行
npm run client进入交互模式,手工测试不同工具
7. 常见问题
连接失败
请检查:
服务端是否已经启动
地址是否正确,默认是
http://localhost:3000/mcp端口是否被其他程序占用
参数解析失败
请检查:
传入的参数是否为合法 JSON
Windows PowerShell 下 JSON 内部双引号是否正确转义
PowerShell 示例:
npm run client -- call match_openapi_interfaces "{\"match_json\":\"{}\",\"openapi_doc\":\"{}\"}"技术栈
Node.js (ESM 模块)
TypeScript (严格模式)
@modelcontextprotocol/sdk (MCP 官方 SDK)
Express (HTTP 服务器)
Zod (参数验证)
扩展指南
添加新工具
在
src/tools.ts中定义新的工具函数使用
server.tool()注册重启服务器即可生效
添加资源能力
如需暴露资源(如文件、数据库查询),可启用 capabilities.resources 并实现相应处理器。
Docker 部署与验证
本项目已配置 Dockerfile,支持容器化部署。服务端默认监听 0.0.0.0:3000 以便在容器外访问。
构建 Docker 镜像:
docker build -t icbc-mcp-demo .运行 Docker 容器:
docker run -d -p 3000:3000 --name mcp-server icbc-mcp-demo使用 Client 验证: 容器启动后,在宿主机上使用内置的 MCP Client 连接并测试工具:
# 列出工具 npm run client -- http://localhost:3000/mcp list # 调用工具 npm run client -- http://localhost:3000/mcp call match_openapi_interfaces "{\"match_json\":\"{}\",\"openapi_doc\":\"{}\"}"停止并删除容器(测试完毕后):
docker stop mcp-server docker rm mcp-server
传统方式部署到生产
使用
npm run build编译使用 PM2 等工具管理进程
配置反向代理(如 Nginx)处理 HTTPS 和负载均衡
许可证
内部示例代码,仅供学习参考。
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/liweipeng11/data-process-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server