协议修订: 草案
用户交互模型
MCP中的资源设计为应用驱动,由主机应用程序根据其需要决定如何集成上下文。 例如,应用程序可以:- 通过UI元素以树状或列表视图展示资源,以便进行明确选择
- 允许用户搜索和筛选可用资源
- 基于启发式方法或AI模型的选择,实现自动上下文包含

能力
支持资源的服务器必须声明resources 能力:
subscribe: 客户端是否可以订阅以接收对个别资源的变更通知。listChanged: 服务器会在可用资源列表发生变化时发出通知。
subscribe 和 listChanged 都是可选的——服务器可以两者都不支持,支持其中之一,或者两者都支持:
协议消息
列出资源
为发现可用资源,客户端会发送resources/list请求。此操作
支持分页。
请求:
请求内容:
读取资源
要获取资源内容,客户端发送一个resources/read请求:
请求:
资源模板
资源模板允许服务器使用 URI模板公开参数化资源。参数可以通过 the completion API自动完成。 请求:列表变更通知
当可用资源列表变更时,声明了listChanged
功能的服务器应当发送通知:
订阅管理
协议支持可选地订阅资源变更。客户端可以订阅特定资源,并在它们发生变化时接收通知: 订阅请求:消息流
数据类型
资源
资源定义包括:uri: 资源的唯一标识符name: 资源的名称。title: 可选的人类可读展示名称,用于标识资源。description: 可选的描述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://
用于表示网络上可用的资源. 服务器 应该 (SHOULD) 仅在客户端能够自行从网络中获取和加载资源时使用此方案——也就是说,不需要通过 MCP 服务器读取该资源。 对于其他用途场景,服务器应当优先使用其他URI方案,或定义一个自定义方案,即使服务器本身将通过互联网下载资源内容。文件://
用于标识行为类似文件系统的资源。但这些资源不需要映射到实际物理文件系统。 MCP servers 可能 使用 XDG MIME 类型(例如inode/directory)来标识表示非常规文件(如目录)的 file:// 资源,这些文件没有标准的 MIME 类型。
git://
Git版本控制集成。自定义URI方案
自定义URI方案必需符合RFC3986标准, 同时需将上述指导原则纳入考量。错误处理
服务器应该 (SHOULD)为标准故障情况返回标准JSON-RPC错误:- 资源未找到:
-32002 - 内部错误:
-32603
安全注意事项
- 服务器必须验证所有资源URI
- 对于敏感资源应该实施访问控制
- 二进制数据必须进行正确编码
- 在执行操作前,必须检查资源权限