SpringBoot集成MCP实现SSE实时通信功能
目录
- SSE 端点
- HTTP 接收端
- 身份校验和权限控制
- 工具注册
- 工具调用
- SSE 推送消息
- 客户端接入(以 CherryStudio 为例)
- 进入 Che编程客栈rryStudio 的 MCP 工具配置面板:
- 输入服务端地址,格式如下:
- 最后
上周五,运营同事发来一句:“这个系统不能让我直接说句话就创建采购单吗?GPT 都能聊天了,你这么死板?”
好家伙,我一个智能生产管理系统 SPMS(Smart Production Management System),确实就是少了点“嘴和耳朵”嘛。
也正巧前段编程客栈时间 MCP(Model Context Protocol)在圈里火了起来。它主打的就是让系统像 GPT 一样和用户自然对话,我们当然不能落后。
于是,我撸起袖子,决定给 SPMS 搭个「MCP 协议」的接口,还要支持 SSE 模式 —— 让系统开口说话、接住请求、智能响应!
01
传统系统没“嘴” 和****“耳朵”********
传统的后台系统,通常是 REST API + 前端页面 + 手动操作:
请求得写死流程;
交互不能说话;
智能化完全靠拼接流程图。
现在,AI 能力接进系统就像长了嘴和耳朵。但是:
怎么接住用户的问题?
怎么从系统里调用逻辑?
怎么把结果发回去?
尤其是我们要用 SSE/HTTP 模式的 MCP,不是大家熟悉的 stdio
模式,就更得好好设计一套交互体系。
02
怎么理解 SSE 模式?
MCP 协议,全称是 Model Context Protocol,简单说,它定义了一个 AI 和系统交互的标准。
我们这次采用的是 MCP 的 SSE(Server-Sent Events)/HTTP 模式,它和我们熟悉的 REST API 很不一样。
可以理解为:
类比 | 功能 | 解释 |
---|---|---|
耳朵 | HTTP 接收端口 | 系统听见了用户的请求 |
嘴巴 | SSE 推送端口 | 系统开口回答用户 |
中枢大脑 | MCP 工具注册与调用 | 系统知道怎么做事 |
SSE 模式最核心的点是——服务端主动推送消息给客户端,而不是等客户端轮询。 |
03
支持 SSE 的 SpringBoot 服务端架构
我们用 SpringBoot 搭了一个完整的 SSE 服务端,结构如下:
┌──────────────┐ │ MCP 客户端 │ └────┬────┬────┘ │ │ SSE连接 HTTP请求 │ │ ┌────▼────┴────┐ │ MCP 控制器 │ ← 拦截器做权限校验 ├──────────────┤ │ /sse/stream ← 建立 SSE 连接 │ /mcp/receive ← 接收 POST 请求 └────┬─────────┘ │ ┌────▼──────┐ │ McpService │ ← 扫描方法 + 执行 + 推送 └───────────┘
SSE 端点
我们使用 /sse/stream
建立连接:
@GetMapping("/sse/stream") public SseEmitter connect(@RequestParam String token) { return sseManager.createEmitter(token); }
HTTP 接收端
收到 MCP 客户端请求,进行工具调用:
@PostMapping("/mcp/receive") public void handle(@RequestBody McpRequest req) { mcpService.invoke(req.getToken(), req.getMethod(), req.getParams()); }
身份校验和权限控制
我们设计了一个 AccessToken -> 用户权限 的映射:
Map<String, Set<String>> tokenToTools = new ConcurrentHashMap<>(); tokenToTools.put("u123-token", Set.of("createOrder", "checkInventory"));
当客户端试图调用一个未授权的方法时,返回:
Error: You are not allowed to use tool 'createPurchaseorder'
每个 token 拥有哪些 MCP 工具,是在服务初始化时通过注解扫描注册的。
04
扫描 MCP 工具 + 执行调用 + SSE 推送
工具注册
我们定义了一个 @McpMethod
 编程客栈;注解:
@Retention(RetentionPolicy.RUNTIME) @Target(ElementType.METHOD) public @interface McpMethod { String name(); // 工具名 String desc(); // 工具描述 }
扫描工具的方法:
@PostConstruct public void scanMcpMetphphods() { // 反射扫描标注了 @McpMethod 的方法并注册 }
工具调用
根据 methodName 找到对应工具,再反射执行:
public Object invoke(String token, String method, Map<String, Object> params) { if (!hASPermission(token, method)) { throw new UnauthorizedException(); } Method tool = toolRegistry.get(method); Object result = tool.inv编程oke(...); sseManager.pushToClient(token, result); return result; }
SSE 推送消息
我们封装了一个 SseManager
工具类,用来管理连接与推送:
public void pushToClient(String token, Object msg) { SseEmitter emitter = emitterMap.get(token); emitter.send(SseEmitter.event().data(msg)); }
客户端接入(以 CherryStudio 为例)
配置 MCP 服务端地址与 AccessToken 即可:
进入 CherryStudio 的 MCP 工具配置面板:
输入服务端地址,格式如下:
http://your-server-host/mcp/sse/stream
注意 /sse/stream
是 MCP 的 Server-Sent Events 推流接口,必须开放访问。
获取 AccessToken:
token 是系统中分配的 AccessToken。
验证是否连接成功:
成功连接后,你将在 CherryStudio 的 MCP 工具栏中看到你定义的服务名称。
点击工具即可开始自然语言交互。
最后
到此这篇关于SpringBoot集成MCP实现SSE实时通信功能的文章就介绍到这了,更多相关SpringBoot MCP实现SSE通信内容请搜索编程客栈(www.devze.com)以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程客栈(www.devze.com)!
精彩评论