使用 JavaScript 和 GrammY 开发 Telegram 机器人

本篇教程将带你从零开始一步步开发一个简单的 Telegram 机器人,基于 GrammY 框架,使用 JavaScript 来编写代码,并将其部署到 Zeabur。

GrammY 框架是什么

  • GrammY - The Telegram Bot Framework

使用 JavaScript 开发 Telegram 机器人有多种选择,例如 node-telegram-bot-api 或 Grammy。第一个是 Telegram 的 Node.js 的 SDK ,GrammY 则是一个新兴的成熟的框架,预先封装好了很多功能,简化我们的开发流程。

Zeabur 是什么

Zeabur 是一个服务部署平台,帮助开发者们很方便地一键部署自己的服务,不再需要担心服务器基础设施。

为了持续运行 Telegram 机器人,我们有两种选择:

  • 本地运行,这就需要电脑保持联网和启动状态
  • 部署上云,开发完毕一键部署到 Zeabur ,持续稳定运行机器人服务

创建机器人并获取令牌

Telegram 创建机器人的流程很简单,打开 Telegram ,搜索 BotFater ,你也可以点击这个链接直达。在聊天页面,按照引导发送 /newbot 命令,创建一个机器人,复制他的令牌。

项目初始化

前置要求

  • 电脑上安装好了 Node.js 环境
  • 安装好了 npm/pnpm 这类包管理器

新建项目

首先,创建一个新文件夹以存放你的机器人代码,然后再该目录下打开终端,键入命令 npm init 生成默认 package.json ,然后再 npm install grammy 安装 grammy 依赖

创建一个 bot.js 文件:

javascript 复制代码
const { Bot } = require("grammy");

const bot = new Bot("在这里填入你的令牌"); 

// 监听信息
bot.on("message:text", (ctx) => ctx.reply("已收到: " + ctx.message.text));

// 启动机器人
bot.start();

此时,你就可以通过以下命令运行你的机器人。

复制代码
node bot.js

运行机器人后,你就可以向刚刚在 Telegram 创建的机器人发送消息,他则会回复"已收到 + 你的信息内容"

部署到 Zeabur

开发完毕后,就可以把你的机器人部署上云,这边推荐使用 Zeabur 来方便地一键部署。

首先打开 Zeabur 的官网,使用 GitHub 注册一个新账号,进入到控制台后,点击创建新项目并选择你喜欢的区域,此处我们选择香港的机房。

创建完毕后,在项目页面点击创立新服务,选择从 GitHub 仓库部署,选择你刚刚创立的机器人仓库,点击导入,Zeabur 就会自动开始部署你的机器人。等待大概一分钟后,部署就能完成了,此时就可以回去和机器人愉快的聊天了~

部署 Telegram 机器人模板

如果你只想拥有一个机器人,能让你在 Telegram 使用 ChatGPT 或者 Gemini ,你也可以直接部署 Zeabur 模板市场里的几个机器人,例如 Gemini-Telegram-Bot 或者 ChatGPT-Telegram-Bot ,点击部署后,Zeabur 会自动为你创建一个对应的仓库,你只需要在部署时填入你的机器人令牌和 API key 就可以开始使用了

相关推荐
前端小菜袅6 分钟前
uniapp配置自动导入uni生命周期等方法
前端·javascript·uni-app
Apifox7 分钟前
如何在 Apifox 中通过 AI 一键生成几十个测试用例?
前端·后端·ai编程
你真的可爱呀8 分钟前
uniapp学习【整体实践】
前端·学习·uni-app·实践
一枚前端小能手15 分钟前
「周更第7期」实用JS库推荐:Vite
前端·javascript·vite
小中123432 分钟前
异步请求的性能提升
前端
我是天龙_绍33 分钟前
渐变层生成器——直接用鼠标拖拽就可以调整渐变层的各种参数,然后可以导出为svg格式
前端
我是天龙_绍1 小时前
Easing 曲线 easings.net
前端
知识分享小能手1 小时前
微信小程序入门学习教程,从入门到精通,电影之家小程序项目知识点详解 (17)
前端·javascript·学习·微信小程序·小程序·前端框架·vue
訾博ZiBo1 小时前
React组件复用导致的闪烁问题及通用解决方案
前端
Dever1 小时前
记一次 CORS 深水坑:开启 withCredentials 后Response headers 只剩 content-type
前端·javascript