协议修订版本: draft
用户交互模型
MCP中的资源设计为由应用驱动,由宿主应用根据其需求决定如何整合上下文。 例如,应用可以:- 通过UI元素显式选择资源,例如树状视图或列表视图
- 允许用户搜索并过滤可用资源
- 根据启发式规则或AI模型的选择,自动包含上下文

功能能力
支持资源的服务器必须声明resources能力:
subscribe:客户端是否可以订阅单个资源的变更通知。listChanged:服务器是否会在可用资源列表发生变化时发出通知。
subscribe和listChanged均为可选项——服务器可以都不支持、只支持其中一个,或两者都支持:
协议消息
列出资源
为了发现可用资源,客户端发送resources/list请求。此操作支持分页。
请求:
读取资源
为了获取资源内容,客户端发送resources/read请求:
请求:
资源模板
资源模板允许服务器使用URI模板暴露参数化资源。参数可以通过补全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://
用于表示网络上的资源。 服务器应该仅在客户端能够自行直接从网络获取并加载资源时使用此方案——也就是说,客户端不需要通过MCP服务器读取该资源。 对于其他用例,服务器应该优先使用其他URI方案,或定义自定义方案,即使服务器本身将通过互联网下载资源内容。file://
用于标识行为类似于文件系统的资源。但资源不需要映射到实际的物理文件系统。 MCP服务器可以使用XDG MIME类型标识file://资源,例如inode/directory,以表示没有标准MIME类型的非常规文件(如目录)。
git://
Git版本控制集成。自定义URI方案
自定义URI方案必须符合RFC3986,并应考虑上述指导。错误处理
服务器应该为常见失败情况返回标准的JSON-RPC错误:- 资源未找到:
-32002 - 内部错误:
-32603
安全考虑
- 服务器必须验证所有资源URI
- 应该对敏感资源实施访问控制
- 二进制数据必须正确编码
- 操作前应该检查资源权限