Agent Scope Java 2.x 系列【9】接入高德 MCP 服务

文章目录

  • [1. 概述](#1. 概述)
  • [2. 原理](#2. 原理)
  • [3. 环境准备](#3. 环境准备)
    • [3.1 获取高德 API Key](#3.1 获取高德 API Key)
    • [3.2 Maven 依赖](#3.2 Maven 依赖)
  • [4. 接入步骤](#4. 接入步骤)
    • [4.1 创建 MCP 客户端](#4.1 创建 MCP 客户端)
    • [4.2 注册到 Toolkit 并构建 Agent](#4.2 注册到 Toolkit 并构建 Agent)
    • [4.3 调用](#4.3 调用)
  • [5. Spring Boot 完整示例](#5. Spring Boot 完整示例)
    • [5.1 配置类](#5.1 配置类)
    • [5.2 application.yml](#5.2 application.yml)
    • [5.3 控制器](#5.3 控制器)
  • [6. 三种传输方式](#6. 三种传输方式)
  • [7. 多 MCP Server 同时接入](#7. 多 MCP Server 同时接入)
  • [8. 自定义 Header 认证](#8. 自定义 Header 认证)

1. 概述

AgentScope 2.0 通过 Toolkit 内置的 MCP 客户端管理器,支持统一接入任意 MCP 兼容服务器。高德地图提供了公开的 MCP Serverhttps://mcp.amap.com),提供地理编码、逆地理编码、天气查询、路线规划等工具。


2. 原理

复制代码
AgentScope                        高德 MCP Server
──────────                        ──────────────
Toolkit                           mcp.amap.com
   │                                  │
   ├─ registerMcpClient()  ──────────→│  建立 streamable-http 连接
   │                                  │
   ├─ 自动 listTools()     ←─────────│  返回 ToolSchema 列表
   │                                  │  (geocode / regeo / weather / direction...)
   │                                  │
   └─ Agent 调用 tool →  callTool() ──→│  执行并返回结果

Toolkit.registerMcpClient(clientWrapper) 注册后,Agent 自动获取 MCP Server 提供的所有工具,无需手动定义。


3. 环境准备

3.1 获取高德 API Key

  1. 访问 高德开放平台 注册账号
  2. 创建应用 → 获取 Key

3.2 Maven 依赖

xml 复制代码
<dependency>
    <groupId>io.agentscope</groupId>
    <artifactId>agentscope</artifactId>
    <version>2.0.0-RC2</version>
</dependency>
<!-- MCP SDK 已由 agentscope 传递依赖引入 -->

4. 接入步骤

4.1 创建 MCP 客户端

高德 MCP Server 使用 streamable-http 传输(也支持其他方式),API Key 通过 URL 查询参数传递:

java 复制代码
import io.agentscope.core.tool.mcp.McpClientBuilder;
import io.agentscope.core.tool.mcp.McpClientWrapper;

// 同步客户端(适合 WebMVC)
McpClientWrapper mcpClient = McpClientBuilder.create("amap")
    .streamableHttpTransport("https://mcp.amap.com/mcp?key=YOUR_AMAP_API_KEY")
    .timeout(Duration.ofSeconds(60))
    .buildSync();  // 同步

// 或异步客户端(适合 WebFlux)
McpClientWrapper mcpClient = McpClientBuilder.create("amap")
    .streamableHttpTransport("https://mcp.amap.com/mcp?key=YOUR_AMAP_API_KEY")
    .timeout(Duration.ofSeconds(60))
    .buildAsync()
    .block();  // 异步初始化

4.2 注册到 Toolkit 并构建 Agent

java 复制代码
Toolkit toolkit = new Toolkit();

// 注册 MCP 客户端(异步初始化)
toolkit.registerMcpClient(mcpClient).block();

// 构建 Agent
ReActAgent agent = ReActAgent.builder()
    .name("amap-assistant")
    .description("高德地图助手")
    .model(DashScopeChatModel.builder()
        .apiKey(System.getenv("DASHSCOPE_API_KEY"))
        .modelName("qwen-plus").build())
    .toolkit(toolkit)
    .sysPrompt("你是一个地图助手,可以使用高德地图提供的工具来查询地理位置、天气、路线规划等。用中文回答。")
    .maxIters(5)
    .build();

4.3 调用

java 复制代码
Msg msg = Msg.builder().role(MsgRole.USER)
    .content(List.of(TextBlock.builder().text("查询北京市朝阳区的天气").build()))
    .build();

Msg reply = agent.call(List.of(msg)).block();
System.out.println(reply.getTextContent());

5. Spring Boot 完整示例

5.1 配置类

java 复制代码
@Configuration
public class AmapAgentConfig {

    @Value("${DASHSCOPE_API_KEY}")
    private String dashscopeKey;

    @Value("${AMAP_API_KEY}")
    private String amapKey;

    @Bean
    public ReActAgent amapAgent() {
        // 1. 创建 MCP 客户端
        McpClientWrapper mcpClient = McpClientBuilder.create("amap")
            .streamableHttpTransport("https://mcp.amap.com/mcp?key=" + amapKey)
            .timeout(Duration.ofSeconds(60))
            .buildSync();

        // 2. 注册到 Toolkit
        Toolkit toolkit = new Toolkit();
        toolkit.registerMcpClient(mcpClient).block();

        // 3. 构建 Agent
        return ReActAgent.builder()
            .name("amap-agent")
            .model(DashScopeChatModel.builder()
                .apiKey(dashscopeKey).modelName("qwen-plus").build())
            .toolkit(toolkit)
            .sysPrompt("""
                你是一个高德地图助手,可以使用以下工具:
                - 地理编码/逆地理编码
                - 天气查询
                - 路线规划
                用中文回答用户问题。
                """)
            .build();
    }
}

5.2 application.yml

yaml 复制代码
server.port: 8090
DASHSCOPE_API_KEY: ${DASHSCOPE_API_KEY:your-key}
AMAP_API_KEY: ${AMAP_API_KEY:your-amap-key}

5.3 控制器

java 复制代码
@RestController
@RequestMapping("/amap")
public class AmapController {

    private final ReActAgent agent;

    @GetMapping("/call")
    public Mono<Map<String, Object>> call(@RequestParam String query) {
        Msg msg = Msg.builder().role(MsgRole.USER)
            .content(List.of(TextBlock.builder().text(query).build()))
            .build();
        return agent.call(List.of(msg))
            .map(r -> Map.of("query", query, "response", r.getTextContent()));
    }

    @GetMapping(value = "/stream", produces = MediaType.TEXT_EVENT_STREAM_VALUE)
    public Flux<String> stream(@RequestParam String query) {
        Msg msg = Msg.builder().role(MsgRole.USER)
            .content(List.of(TextBlock.builder().text(query).build()))
            .build();
        return agent.streamEvents(List.of(msg))
            .filter(e -> e instanceof TextBlockDeltaEvent)
            .map(e -> "data: " + ((TextBlockDeltaEvent) e).getDelta() + "\n\n");
    }
}

6. 三种传输方式

AgentScopeMcpClientBuilder 支持三种 MCP 传输协议:

传输方式 方法 适用场景
Streamable HTTP(推荐) streamableHttpTransport(url) 远程 MCP Server,如高德
SSE sseTransport(url) 兼容旧版 MCP Server
Stdio stdioTransport(command, args...) 本地进程,如本地 Python MCP Server
java 复制代码
// Streamable HTTP(高德)
McpClientBuilder.create("amap")
    .streamableHttpTransport("https://mcp.amap.com/mcp?key=xxx")
    .buildSync();

// SSE
McpClientBuilder.create("weather")
    .sseTransport("http://localhost:8080/sse")
    .buildSync();

// 本地 Stdio
McpClientBuilder.create("local-tool")
    .stdioTransport("python", List.of("-m", "my_mcp_server"))
    .buildSync();

7. 多 MCP Server 同时接入

java 复制代码
Toolkit toolkit = new Toolkit();

// 高德地图
McpClientWrapper amap = McpClientBuilder.create("amap")
    .streamableHttpTransport("https://mcp.amap.com/mcp?key=" + amapKey)
    .buildSync();

// 自定义 MCP Server
McpClientWrapper custom = McpClientBuilder.create("custom")
    .sseTransport("http://localhost:19000")
    .buildSync();

// 同时注册
toolkit.registerMcpClient(amap).block();
toolkit.registerMcpClient(custom).block();

ReActAgent agent = ReActAgent.builder()
    .name("multi-mcp-agent")
    .model(model)
    .toolkit(toolkit)
    .build();

Agent 自动获得两个 MCP Server 的全部工具,LLM 会根据查询选择合适的工具调用。


8. 自定义 Header 认证

部分 MCP Server 需要 Bearer TokenHeader 认证:

java 复制代码
McpClientWrapper client = McpClientBuilder.create("secure-mcp")
    .streamableHttpTransport("https://secure-mcp.example.com/mcp")
    .header("Authorization", "Bearer " + token)
    .header("X-Custom-Header", "value")
    .timeout(Duration.ofSeconds(30))
    .buildSync();

相关推荐
qq3621967051 小时前
第三方安卓应用商店安全评测 2026:Appteka、Aptoide、APKPure 等 7 家横评
android·网络·人工智能·安全·chatgpt·智能手机
qq_291579252 小时前
电商主图优化实战指南:AI工具如何提升点击率与转化率
大数据·人工智能·深度学习
机器学习之心2 小时前
基于 GRU-Attention 的多工况车速预测:当序列建模遇见自注意力
人工智能·深度学习·gru·多工况车速预测
AI创界者2 小时前
【解压即用】Scail-2 视频动作迁移一键整合包:8G显存通吃50系,长视频/多人/精准目标替换全攻略
人工智能·python·aigc·音视频
土星云SaturnCloud2 小时前
从云端到边缘:电子装配线AI视频分析在土星云SE110S-WA32上的落地实践
服务器·人工智能·ai·边缘计算
gaohe26AIliuzeyu2 小时前
Java内部类
java·开发语言
西安邮电大学2 小时前
有关数组的经典算法题
java·后端·其他·算法·面试
浔川python社2 小时前
访问量即将突破 22 万,步履不停再启新篇
人工智能·浔川代码编辑器·浔川ai翻译
互联网推荐官2 小时前
上海AI Agent智能体开发公司技术选型实录:六条路径、三类架构与真实落地约束
java·人工智能·ai·架构·开发经验·上海