一日一撸(No.2):把 Claude Code 装进 Telegram:一个周末的轻量级方案

3 月 5 日
 TerranC

Telegram Skill Bot:把 Claude Code 装进手机

起因:一个周末的小烦恼

上周末突然要出门,结果出门后突然想起有个 bug 没修。打开手机想用 Claude Code 看一眼,结果发现——它只能在终端里跑

回家开电脑?太麻烦了。用 OpenClaw ?我试过,配置 Web 服务器、Nginx 反向代理、HTTPS 证书……折腾了一下午,最后发现我只是想改几行代码而已。

这时候我想:能不能直接在 Telegram 里跟 Claude 聊天?

Telegram 有现成的 Bot API ,不需要自己搭服务器,消息推送也是长连接,安全性由 Telegram 保证。听起来很适合做这件事。

于是周末两天,撸了个 Telegram Bot 版本的 Claude Code 遥控器。

痛点:为什么不用 OpenClaw ?

OpenClaw 是个很棒的项目,但它解决的是"把 Claude 搬到云端"的问题,适合团队协作或者需要完整 Web IDE 的场景。

我的需求更简单:

所以我需要的是一个"轻量级的后门",而不是一个完整的 Web 应用。

项目特点

1. 零基础设施

不需要 Web 服务器、不需要端口暴露、不需要配置 HTTPS 。Telegram 自带长连接,消息推送由 Telegram 服务器处理。启动一次就作为守护进程在后台运行,崩溃自动重启,macOS 上还能配置开机自启。

2. 默认安全

3. 实时流式响应

Claude 的回复不是等全部生成完才显示,而是边思考边更新。使用 Telegram 草稿消息 API ,每 150 字符或 1 秒更新一次。你能看到 Claude 实时打字的过程,就像在终端里用 Claude Code 一样。长消息(超过 4000 字符)自动分段发送,体验很流畅。

4. 语音消息支持

直接发送 Telegram 语音消息,Bot 会自动:

在路上也能用语音跟 Claude 对话,不用打字。

5. 智能交互

6. 功能完整

上手指南

用 Claude Code 自动安装(推荐)

git clone https://github.com/terranc/claude-telegram-bot-bridge
cd claude-telegram-bot-bridge
claude

然后在 Claude Code 提示符里输入 /setup,它会自动帮你:

/setup 技能支持多语言交互,你可以用中文、英文、日文等任何语言完成安装。

完成后启动:

./start.sh --path /path/to/your/project

手动安装

如果不想用 Claude Code ,也可以直接运行安装脚本:

git clone https://github.com/terranc/claude-telegram-bot-bridge
cd claude-telegram-bot-bridge
./setup.sh

获取 Telegram Bot Token

@BotFather 创建一个 Bot ,拿到 Token 。

获取你的 Telegram 用户 ID

@userinfobot 发消息,它会告诉你你的用户 ID 。

语音消息配置(可选)

如果想使用语音消息功能,需要:

  1. OpenAI API Key (用于 Whisper 转录)
  2. ffmpeg (用于音频格式转换)

.env 文件中配置:

OPENAI_API_KEY=your_openai_api_key
WHISPER_MODEL=whisper-1  # 可选,默认 whisper-1
MAX_VOICE_DURATION=300   # 可选,最大时长(秒),默认 300

语音转录费用约为 $0.006/分钟(以 OpenAI 官方定价为准)。

常用命令

# 前台运行(默认)
./start.sh --path /path/to/project

# 后台守护进程
./start.sh --path /path/to/project -d

# 调试模式(详细日志 + 聊天记录)
./start.sh --path /path/to/project --debug

# 检查运行状态
./start.sh --path /path/to/project --status

# 停止
./start.sh --path /path/to/project --stop

# macOS 开机自启
./start.sh --path /path/to/project --install

# 取消开机自启
./start.sh --path /path/to/project --uninstall

Telegram 内的命令

技术细节

架构

关键数据流

文本消息流程: 用户消息 → TelegramBot 处理器 → 权限检查 → ProjectChatHandler.process_message() → Claude SDK 流式响应 → 实时更新草稿消息 → 返回 Telegram

语音消息流程: 用户语音 → 下载音频文件 → 格式检测 → ffmpeg 转换(如需要)→ Whisper 转录 → 显示 🎤 Voice: 预览 → 转发给 Claude → 同文本消息流程

权限控制: 工具请求 → _permission_callback() → 项目内自动允许 / 项目外弹出内联按钮 → 用户选择( Allow / Deny / Allow All )→ asyncio.Future 模式等待响应( 60 秒超时)

流式响应: Claude SDK 流 → 每 150 字符或 1 秒触发更新 → Telegram 草稿消息 API → 超过 4000 字符自动分段 → 最终消息发送

优先级命令/stop/revert → 绕过消息队列限制 → 立即取消活动任务(asyncio.Task.cancel())→ 清理草稿消息 / 停止 SDK 流 / 删除临时音频文件

数据存储

守护进程特性

项目地址

GitHub: https://github.com/terranc/claude-telegram-bot-bridge

欢迎提 Issue 或 PR 。如果你也觉得 OpenClaw 太重,可以试试这个方案。

后记

这个项目从想法到能用,大概花了一个周末。后来陆续加了语音消息、流式响应优化、优先级命令等功能,现在已经是我日常开发的必备工具。

有时候工具不需要很完美,够用就行。OpenClaw 是一辆卡车,我这个是一辆自行车——看你要运货还是通勤。

现在我在地铁上也能用手机跟 Claude 对话,让它帮我改代码、跑测试、查日志。实时流式响应让整个体验很流畅,就像在终端里用 Claude Code 一样。语音消息功能让我在路上也能用语音跟 Claude 交流,不用打字。

下一步可能会加个会话回滚功能(/revert),可以回到对话历史的任意节点,恢复代码状态或重新开始。不过这是后话了。

先这样,继续撸代码去了 🚀

432 次点击
所在节点    Telegram
0 条回复

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/1196012

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX