MCP服务 SSE / Streamable HTTP 这两种数据传输机制,怎么用 http 请求查询这个MCP服务支持哪些工具调用, 和怎么调用其中一个工具

写这个的目的,主要是好奇,想了解MCP服务 底层的原理。

拿 高德 mcp 服务 举例
1 查询 高德 mcp 服务 , 提供了哪些工具可以调用

这4个参数是 JSON-RPC 2.0 协议的标准字段,作用如下:

  • jsonrpc: "2.0":声明使用的协议版本。

  • id: 1:请求的唯一编号,用于将响应与当前请求配对。

  • method: "tools/list":要执行的方法名,即"获取工具列表"。

  • params: {}:方法所需的参数,此处为空表示不需要额外传参。

    curl --location --request POST 'https://mcp.amap.com/mcp?key=xxxxxxxx'
    --header 'Accept: application/json, text/event-stream'
    --header 'User-Agent: Apifox/1.0.0 (https://apifox.com)'
    --header 'Content-Type: application/json'
    --header 'Host: mcp.amap.com'
    --header 'Connection: keep-alive'
    --data-raw '{
    "jsonrpc": "2.0",
    "id": 1,
    "method": "tools/list",
    "params": {}
    }'

2 调用 某个工具,如查天气

  • jsonrpc: "2.0":声明遵循 JSON-RPC 2.0 协议版本。

  • id: 3:本次请求的唯一标识符,用于匹配服务器返回的响应结果。

  • method: "tools/call":指定要执行的方法为"调用工具"。

  • params:包含调用该工具所需的具体参数对象,内部细分为:

  • name: "maps_weather":指明要调用的具体工具名称。

  • arguments:传递给该工具的输入参数,这里传入了 {"city": "北京"}。

    curl --location --request POST 'https://mcp.amap.com/mcp?key=xxxxxxxx'
    --header 'Accept: application/json, text/event-stream'
    --header 'User-Agent: Apifox/1.0.0 (https://apifox.com)'
    --header 'Content-Type: application/json'
    --header 'Host: mcp.amap.com'
    --header 'Connection: keep-alive'
    --data-raw '{
    "jsonrpc": "2.0",
    "id": 3,
    "method": "tools/call",
    "params": {
    "name": "maps_weather",
    "arguments": {
    "city": "北京"
    }
    }
    }'

3 调用 某个工具,根据 经纬度 查询地址

复制代码
curl --location --request POST 'https://mcp.amap.com/mcp?key=xxxxxxxx' \
--header 'Accept:  application/json, text/event-stream' \
--header 'User-Agent: Apifox/1.0.0 (https://apifox.com)' \
--header 'Content-Type: application/json' \
--header 'Host: mcp.amap.com' \
--header 'Connection: keep-alive' \
--data-raw '{
  "jsonrpc": "2.0",
  "id": 1,
  "method": "tools/call",
  "params": {
    "name": "maps_regeocode",
    "arguments": {
      "location": "116.397128,39.916527"
    }
  }
}'
相关推荐
艾莉丝努力练剑1 小时前
【Qt】事件
服务器·开发语言·网络·数据库·qt·tcp/ip·计算机网络
weixin_604236671 小时前
华为企业级路由器完整版实战配置
网络·安全·华为·智能路由器·华为交换机命令·华为路由器
洛水水1 小时前
图床项目实现:注册登录 + 文件上传等功能的完善
网络·c++·mysql·图床
呉師傅1 小时前
联想M7400Pro提示无法打印0B 关闭电源然后重新打开故障维修分享
运维·网络·windows·电脑
zbtlink1 小时前
买路由器,到底是在买什么?
网络·智能路由器
艾莉丝努力练剑1 小时前
【QT】窗口
运维·网络·数据库·qt·计算机网络·microsoft
程序员二叉1 小时前
【计算机网络】面试全解|OSI/TCPIP、HTTP全版本、HTTPS、DNS一站式梳理
计算机网络·http·面试
yyuuuzz1 小时前
aws亚马逊云服务的基础认知与常见场景
大数据·运维·服务器·网络·云计算·aws
程思扬2 小时前
Android 大厂编码规范
android·网络·安全·开源·流程图