1. 在 AnakinAI 平台内创建 AI App
2. 申请 Telegram Bot Token
3. 在 Cloudflare Workers 内部署 Bot 程序
4. 开始对话
Telegram Bot 本身还提供了丰富的 API 能力,你甚至还可以在后端的 AI App 内接入知识库,直接让 Bot 来充当 AI 智能客服!
准备工作
-
Telegram 账号/客户端(本文默认你已经能够正常访问,不会涉及任何注册指导)
-
Cloudflare 账号
-
在 Anakin.ai 内创建 AI App
1. 申请 Telegram Bot
在 Telegram 内搜索 @BotFather ,然后点击 "Start" 按钮,然后输入 /newbot 命令,按照提示输入 Bot 的名字和 username。
获取 HTTP API Token,这是与 Telegram Bot 交互的唯一凭证,请妥善保管。
2. 申请 AnakinAI 应用 API Access Key
本文将会以 Anakin.ai 作为 AI 应用的创建平台作为示例。
Anakin.ai 是一站式 AI 应用平台,上面已经预置了大量好用的 AI App。你可以随意挑选并克隆至自己的工作空间内,或者非常轻易地搭建出属于自己的 AI App。支持中文!!
注册 Anakin.ai 后,点击左下角的头像,在 "API Access Token" tab 页中生成你自己的 API Access Key,这是 TG Bot 与 AI App 通讯的唯一凭证,请妥善保管。
克隆或自建 AI 应用,然后在应用的“应用集成” tab 页找到 App ID。
注意
-
API Key 仅展示一次,请妥善保存。
-
不要在 URL 内明文传输 Key,避免泄露而造成预期之外的 Credits 消耗
3. 将 AI App 集成至 TG Bot
原理说明
用户在与 Telegram Bot 对话时,Bot 将会将用户输入的对话信息通过 API 发送至 Anakin App,Anakin App 再根据用户输入的文本生成回复内容,并将回复内容通过 API 返回至 Telegram Bot,最终由 Telegram Bot 再将回复内容发送至用户。
3.1 部署 Telegram 请求程序
在 VPS 或 Serverless 服务上部署一个 Telegram 请求后端程序,用于接收并处理用户发送给 Telegram Bot 的消息,并将请求信息发送至 Anakin API 进行处理,最后再传递回用户。
本章节将以 Cloudflare Workers 为例,部署一个 Telegram 请求程序。
Workers 免费注册地址:
https://dash.cloudflare.com/workers-and-pages
点击 "Workers & Pages" tab 页中的 Overview,然后轻点 "创建应用程序" 按钮。
点击 "创建 Worker" 按钮,重命名 Worker 名称。在代码框内复制粘贴以下代码,并将以下参数替换为自己的 ID。
YOUR_TELEGRAM_BOT_TOKEN
YOUR_BOT_USERNAME、YOUR_ANAKINAI_API_KEY
ChatbotId 替换为上文中的 App ID
const telegramAuthToken = 'YOUR_TELEGRAM_BOT_TOKEN';
const webhookEndpoint = "/endpoint";
const botUsername = "@YOUR_BOT_USERNAME"; // 替换为您的机器人用户名
addEventListener("fetch", event => {
event.respondWith(handleIncomingRequest(event));
});
async function handleIncomingRequest(event) {
let url = new URL(event.request.url);
let path = url.pathname;
let method = event.request.method;
let workerUrl = `${url.protocol}//${url.host}`;
// 在启动时设置 Webhook
if (method === "GET" && path === "/") {
const webhookUrl = `https://api.telegram.org/bot${telegramAuthToken}/setWebhook?url=${workerUrl}${webhookEndpoint}`;
const response = await fetch(webhookUrl);
if (response.ok) {
return new Response("Webhook set successfully", { status: 200 });
} else {
return new Response("Failed to set webhook", { status: response.status });
}
}
if (method === "POST" && path === webhookEndpoint) {
const update = await event.request.json();
event.waitUntil(processUpdate(update));
return new Response("Ok");
} else if (method === "GET" && path === "/configure-webhook") {
const url = `https://api.telegram.org/bot${telegramAuthToken}/setWebhook?url=${workerUrl}${webhookEndpoint}`;
const response = await fetch(url);
if (response.ok) {
return new Response("Webhook set successfully", { status: 200 });
} else {
return new Response("Failed to set webhook", { status: response.status });
}
} else {
return new Response("Not found", { status: 404 });
}
}
async function processUpdate(update) {
let chatId, userText, responseText;
if ("message" in update) {
const message = update.message;
chatId = message.chat.id;
userText = message.text;
// 检查是否为群组消息并且提及了机器人
if (message.chat.type === "group" || message.chat.type === "supergroup") {
if (userText.includes(botUsername)) {
userText = userText.replace(botUsername, "").trim();
} else {
// 如果没有提及机器人,则不响应
return;
}
}
const apiKey = 'YOUR_ANAKINAI_API_KEY'; // 替换为您的 API 密钥
const chatbotId = 'ChatbotId'; // 替换为您的 Chatbot ID
const myHeaders = new Headers();
myHeaders.append("X-Anakin-Api-Version", "2024-05-06");
myHeaders.append("User-Agent", "Apidog/1.0.0 (https://apidog.com)");
myHeaders.append("Content-Type", "application/json");
myHeaders.append("Authorization", `Bearer ${apiKey}`);
const raw = JSON.stringify({ "content": userText, "stream": false });
const requestOptions = {
method: 'POST',
headers: myHeaders,
body: raw,
redirect: 'follow'
};
const response = await fetch(`https://api.anakin.ai/v1/chatbots/${chatbotId}/messages`, requestOptions);
const result = await response.json();
console.log('API response:', result); // 打印出完整的 API 响应数据
// 从响应数据中取出 content 字段的值
const responseText = result.content || "Sorry, I couldn't get a response.";
const url = `https://api.telegram.org/bot${telegramAuthToken}/sendMessage?chat_id=${chatId}&text=${encodeURIComponent(responseText)}`;
await fetch(url);
} else {
// 处理其他类型的更新
return;
}
}
然后点击右上角 "部署" 按钮。
3.2 测试 Telegram Bot
在 Telegram 内搜索你的 Bot 名字。点击进入并开始聊天。你也可以在 @BotFather 内输入 /mybots 命令来查看你的 Bot 名称。
向 Bot 发送消息,你可以看到由 AI 生成的回复内容。
4. 将 Bot 添加至群组
在添加 Bot 至群组之前,你需要确保已设置相应的隐私策略。前往 @BotFather,输入 /mybots 命令,开启 Allow Groups 并关闭 Group Privacy 设置。
群组内的用户可以直接 @bot 并进行对话聊天
注意
多人群聊可能会加速 Bot 的 Credits 消耗,请及时关注你的 Credits 余额。访问 Anakin.ai,点击右下角的 Credits 余额,然后在 "升级/续费" → “额度明细” 内查看你的 Credits 使用记录。
总结
版权声明:本站资源来自互联网收集,仅供用于学习和交流,请勿用于商业用途。如有侵权、不妥之处,请联系客服并出示版权证明以便删除!