Channel 是一个 MCP 服务器,它将事件推送到您运行中的 Claude Code 会话中,以便 Claude 可以对您不在终端时发生的事情做出反应。Channels 可以是双向的:Claude 读取事件并通过同一 channel 回复,就像聊天桥接一样。事件仅在会话打开时到达,因此对于始终在线的设置,您可以在后台进程或持久终端中运行 Claude。
与生成新的云会话或等待被轮询的集成不同,事件到达您已经打开的会话中:请参阅 channels 如何比较。
您将 channel 作为插件安装并使用您自己的凭据配置它。Telegram、Discord 和 iMessage 包含在研究预览中。
当 Claude 通过 channel 回复时,您会在终端中看到入站消息,但看不到回复文本。终端显示工具调用和确认(如”已发送”),实际回复出现在其他平台上。
本页涵盖:
- 支持的 channels:Telegram、Discord 和 iMessage 设置
- 安装并运行 channel,使用 fakechat(本地主机演示)
- 谁可以推送消息:发送者允许列表以及如何配对
- 为您的组织启用 channels(Team 和 Enterprise)
- channels 如何比较与网络会话、Slack、MCP 和远程控制
支持的 channels
每个支持的 channel 都是一个需要 Bun 的插件。在连接真实平台之前,要获得插件流程的实际演示,请尝试 fakechat 快速入门。- Telegram
- Discord
- iMessage
查看完整的 Telegram 插件源代码。
创建 Telegram 机器人
在 Telegram 中打开 BotFather 并发送
/newbot。给它一个显示名称和一个以 bot 结尾的唯一用户名。复制 BotFather 返回的令牌。安装插件
在 Claude Code 中,运行:如果 Claude Code 报告在任何市场中都找不到该插件,您的市场可能缺失或已过期。运行
/plugin marketplace update claude-plugins-official 来刷新它,或者如果您之前没有添加过,运行 /plugin marketplace add anthropics/claude-plugins-official。然后重试安装。安装后,运行 /reload-plugins 来激活插件的配置命令。配置您的令牌
使用来自 BotFather 的令牌运行配置命令:这会将其保存到
~/.claude/channels/telegram/.env。您也可以在启动 Claude Code 之前在 shell 环境中设置 TELEGRAM_BOT_TOKEN。快速入门
Fakechat 是一个官方支持的演示 channel,在 localhost 上运行聊天 UI,无需身份验证,也无需配置外部服务。 安装并启用 fakechat 后,您可以在浏览器中输入,消息会到达您的 Claude Code 会话。Claude 回复,回复会显示在浏览器中。测试了 fakechat 界面后,尝试 Telegram、Discord 或 iMessage。 要尝试 fakechat 演示,您需要:- Claude Code 已安装并使用 claude.ai 账户进行身份验证
- Bun 已安装。预构建的 channel 插件是 Bun 脚本。使用
bun --version检查;如果失败,安装 Bun。 - Team/Enterprise 用户:您的组织管理员必须在托管设置中启用 channels
安装 fakechat channel 插件
启动 Claude Code 会话并运行安装命令:如果 Claude Code 报告在任何市场中都找不到该插件,您的市场可能缺失或已过期。运行
/plugin marketplace update claude-plugins-official 来刷新它,或者如果您之前没有添加过,运行 /plugin marketplace add anthropics/claude-plugins-official。然后重试安装。推送消息进来
在 http://localhost:8787 打开 fakechat UI 并输入消息:消息作为
<channel source="fakechat"> 事件到达您的 Claude Code 会话。Claude 读取它,完成工作,并调用 fakechat 的 reply 工具。答案显示在聊天 UI 中。--dangerously-skip-permissions 完全绕过提示,但仅在您信任的环境中使用。
安全性
每个批准的 channel 插件都维护一个发送者允许列表:只有您添加的 ID 可以推送消息,其他所有人都会被静默丢弃。 Telegram 和 Discord 通过配对来引导列表:- 在 Telegram 或 Discord 中找到您的机器人并向其发送任何消息
- 机器人回复一个配对代码
- 在您的 Claude Code 会话中,在提示时批准代码
- 您的发送者 ID 被添加到允许列表
/imessage:access allow 通过句柄添加其他联系人。
除此之外,您可以使用 --channels 控制每个会话启用哪些服务器,在 Team 和 Enterprise 计划上,您的组织可以使用 channelsEnabled 控制可用性。
仅在 .mcp.json 中还不足以推送消息:服务器还必须在 --channels 中命名。
允许列表也会限制权限中继(如果 channel 声明了它)。任何可以通过 channel 回复的人都可以批准或拒绝您会话中的工具使用,因此只允许列表您信任具有该权限的发送者。
Enterprise 控制
在 Team 和 Enterprise 计划上,channels 默认关闭。管理员通过两个托管设置控制可用性,用户无法覆盖:| 设置 | 目的 | 未配置时 |
|---|---|---|
channelsEnabled | 主开关。必须为 true 才能让任何 channel 传递消息。通过 claude.ai 管理员控制台切换或直接在托管设置中设置。关闭时阻止所有 channels,包括开发标志。 | Channels 被阻止 |
allowedChannelPlugins | 启用 channels 后哪些插件可以注册。设置时替换 Anthropic 维护的列表。仅在 channelsEnabled 为 true 时适用。 | 应用 Anthropic 默认列表 |
--channels 按会话选择加入。
为您的组织启用 channels
管理员可以从 claude.ai → 管理员设置 → Claude Code → Channels 启用 channels,或通过在托管设置中将channelsEnabled 设置为 true。
启用后,您组织中的用户可以使用 --channels 将 channel 服务器选择加入到各个会话中。如果设置被禁用或未设置,MCP 服务器仍会连接,其工具可以工作,但 channel 消息不会到达。启动警告会告诉用户让管理员启用该设置。
限制哪些 channel 插件可以运行
默认情况下,Anthropic 维护的允许列表上的任何插件都可以注册为 channel。Team 和 Enterprise 计划上的管理员可以通过在托管设置中设置allowedChannelPlugins 来替换该允许列表。使用此功能来限制允许哪些官方插件、批准来自您自己的内部市场的 channels,或两者兼有。每个条目命名一个插件及其来自的市场:
allowedChannelPlugins 时,它完全替换 Anthropic 允许列表:只有列出的插件可以注册。保持未设置以回退到默认 Anthropic 允许列表。空数组阻止所有 channel 插件从允许列表中,但 --dangerously-load-development-channels 仍可以为本地测试绕过它。要完全阻止 channels,包括开发标志,请改为保持 channelsEnabled 未设置。
此设置需要 channelsEnabled: true。如果用户将不在您列表中的插件传递给 --channels,Claude Code 会正常启动,但 channel 不会注册,启动通知会解释该插件不在组织的批准列表中。
研究预览
Channels 是一个研究预览功能。可用性正在逐步推出,--channels 标志语法和协议契约可能会根据反馈而改变。
在预览期间,--channels 仅接受来自 Anthropic 维护的允许列表的插件,或来自您组织的允许列表(如果管理员已设置 allowedChannelPlugins)。claude-plugins-official 中的 channel 插件是默认批准的集合。如果您传递不在有效允许列表中的内容,Claude Code 会正常启动,但 channel 不会注册,启动通知会告诉您原因。
要测试您正在构建的 channel,请使用 --dangerously-load-development-channels。有关测试您构建的自定义 channels 的信息,请参阅在研究预览期间测试。
在 Claude Code GitHub 存储库上报告问题或反馈。
channels 如何比较
几个 Claude Code 功能连接到终端外的系统,每个都适合不同类型的工作:| 功能 | 它做什么 | 适合 |
|---|---|---|
| 网络上的 Claude Code | 在新的云沙箱中运行任务,从 GitHub 克隆 | 委派您稍后检查的自包含异步工作 |
| Slack 中的 Claude | 从频道或线程中的 @Claude 提及生成网络会话 | 直接从团队对话上下文启动任务 |
| 标准 MCP 服务器 | Claude 在任务期间查询它;没有任何内容被推送到会话 | 给 Claude 按需访问以读取或查询系统 |
| 远程控制 | 您从 claude.ai 或 Claude 移动应用程序驱动您的本地会话 | 在离开您的办公桌时指导进行中的会话 |
- 聊天桥接:通过 Telegram、Discord 或 iMessage 从您的手机向 Claude 询问某事,答案会在同一聊天中返回,而工作在您的机器上针对您的真实文件运行。
- Webhook 接收器:来自 CI、您的错误跟踪器、部署管道或其他外部服务的 webhook 到达 Claude 已经打开您的文件并记得您正在调试的内容的地方。
后续步骤
一旦您有一个 channel 运行,请探索这些相关功能:- 构建您自己的 channel,用于尚未有插件的系统
- 远程控制,从您的手机驱动本地会话,而不是将事件转发到其中
- 计划任务,按计时器轮询而不是对推送事件做出反应