协议修订: 2025-11-25
用户交互模型
MCP 中的资源设计为应用驱动型,由宿主应用根据其需求决定如何整合上下文。 例如,应用可以:- 通过 UI 元素(如树状图或列表视图)公开资源以供显式选择
- 允许用户搜索和过滤可用资源
- 根据启发式算法或 AI 模型的选择实现自动上下文包含

功能
支持资源的服务器必须声明resources 能力
subscribe:客户端是否可以订阅单个资源的更改通知。listChanged:当可用资源列表发生变化时,服务器是否会发出通知。
subscribe 和 listChanged 都是可选的——服务器可以都不支持,支持其中之一,或两者都支持
协议消息
列举资源
要发现可用资源,客户端发送resources/list 请求。此操作支持分页。 请求:读取资源
要检索资源内容,客户端发送resources/read 请求: 请求:资源模板
资源模板允许服务器使用 URI 模板公开参数化资源。参数可以通过补全 API 自动补全。 请求:列表变更通知
当可用资源列表发生变化时,声明了listChanged 能力的服务器应当发送通知
订阅
协议支持可选的资源更改订阅。客户端可以订阅特定资源,并在其更改时接收通知: 订阅请求:消息流
数据类型
资源
资源定义包括uri:资源的唯一标识符name:资源的名称。title:可选的用于显示的人类可读资源名称。description:可选描述icons: 用于在用户界面中显示的可选图标数组mimeType:可选 MIME 类型size:可选的字节大小
资源内容
资源可以包含文本或二进制数据文本内容
二进制内容
注解
资源、资源模板和内容块支持可选注解,为客户端提供有关如何使用或显示资源的提示audience:一个数组,指示此资源的预期受众。有效值为"user"和"assistant"。例如,["user", "assistant"]表示内容对两者都有用。priority:一个 0.0 到 1.0 之间的数字,指示此资源的重要性。值为 1 表示“最重要”(实际上是必需的),而 0 表示“最不重要”(完全可选)。lastModified:ISO 8601 格式的时间戳,指示资源上次修改的时间(例如"2025-01-12T15:00:58Z")。
- 根据预期受众过滤资源
- 优先考虑哪些资源包含在上下文中
- 显示修改时间或按新鲜度排序
常见 URI 方案
协议定义了几种标准的 URI 方案。此列表并非详尽无遗——具体实现始终可以自由使用额外的自定义 URI 方案。https://
用于表示 Web 上可用的资源。 服务器应当仅在客户端能够自行从 Web 获取并加载资源时才使用此方案——也就是说,它不需要通过 MCP 服务器读取资源。 对于其他用例,服务器应当优先使用另一种 URI 方案,或定义自定义方案,即使服务器本身将通过互联网下载资源内容。file://
用于标识行为类似于文件系统的资源。然而,资源不需要映射到真实的物理文件系统。 MCP 服务器可以使用 XDG MIME 类型(如inode/directory)来标识 file:// 资源,以表示没有标准 MIME 类型的非正规文件(如目录)。git://
Git 版本控制集成。自定义 URI 方案
自定义 URI 方案必须符合 RFC3986,并考虑上述指导建议。错误处理
服务器应该为常见的失败情况返回标准的 JSON-RPC 错误- 资源未找到:
-32002 - 内部错误:
-32603
安全注意事项
- 服务器必须验证所有资源 URI
- 应当为敏感资源实施访问控制
- 二进制数据必须经过正确编码
- 在操作前应当检查资源权限