协议修订: 2024-11-05
用户交互模型
MCP中的资源被设计为应用程序驱动,主机应用程序根据其需求确定如何纳入上下文。 例如,应用程序可以:- 通过UI元素暴露资源以进行显式选择,在树或列表视图中
- 允许用户搜索和过滤可用资源
- 实现自动上下文包含,基于启发式或AI模型的选择

功能
支持资源的服务器必须声明resources 功能:
subscribe:客户端是否可以订阅以接收单个资源更改的通知。listChanged:服务器是否会在可用资源列表更改时发出通知。
subscribe 和 listChanged 都是可选的——服务器可以不支持任何一个、任何一个或两个都支持:
协议消息
列出资源
要发现可用资源,客户端发送resources/list 请求。此操作支持分页。
请求:
读取资源
要检索资源内容,客户端发送resources/read 请求:
请求:
资源模板
资源模板允许服务器使用URI模板暴露参数化资源。参数可以通过完成API自动完成。 请求:列表更改通知
当可用资源列表更改时,声明了listChanged 功能的服务器应该发送通知:
订阅
协议支持可选的资源更改订阅。客户端可以订阅特定资源,并在它们更改时接收通知: 订阅请求:消息流程
数据类型
资源
资源定义包括:uri:资源的唯一标识符name:人类可读名称description:可选描述mimeType:可选MIME类型
资源内容
资源可以包含文本或二进制数据:文本内容
二进制内容
常见URI方案
协议定义了几个标准URI方案。这个列表不是详尽的——实现总是可以自由使用额外的自定义URI方案。https://
用于表示网上可用的资源。 服务器应该仅在客户端能够自行从网上获取和加载资源时使用此方案——也就是说,它不需要通过MCP服务器读取资源。 对于其他用例,服务器应该更喜欢使用另一个URI方案,或定义一个自定义的,即使服务器本身将通过互联网下载资源内容。file://
用于标识行为像文件系统的资源。但是,资源不需要映射到实际的物理文件系统。 MCP服务器可以使用XDG MIME类型,如inode/directory,来标识file://资源,以表示没有标准MIME类型的非常规文件(如目录)。
git://
Git版本控制集成。错误处理
服务器应该为常见失败情况返回标准JSON-RPC错误:- 资源未找到:
-32002 - 内部错误:
-32603
安全考虑
- 服务器必须验证所有资源URI
- 访问控制应该为敏感资源实现
- 二进制数据必须正确编码
- 资源权限应该在操作前检查