Telegramm-Webhook
Verabschieden Sie sich vom Umfragemodus und nutzen Sie den effizienten Telegram-Webhook! Im Gegensatz zur Polling-Methode, die kontinuierlich Aktualisierungen vom Telegram-Server anfordert, ermöglicht Webhook Telegram, Aktualisierungen direkt an Ihren Server zu übertragen, wodurch der Ressourcenverbrauch des Servers reduziert und die Effizienz erheblich verbessert wird. In einem früheren Artikel habe ich erklärt, wie man mit Node.js einen Telegram-Roboter erstellt und die Polling-Methode verwendet, um Updates zu erhalten. Dieser Ansatz funktioniert zwar, aber wenn Sie auf der Suche nach Skalierbarkeit sind, auch wenn Sie derzeit keine Ratenbeschränkungen haben, stellt der Wechsel zu Webhooks sicher, dass Ihr Bot effizienter läuft und steigenden Datenverkehr problemlos bewältigen kann, wodurch die Belastung Ihrer Server verringert wird.
Wichtige Überlegungen zum Telegram Webhook
Achten Sie bei der Verwendung von Webhooks unbedingt auf folgende Punkte:
Zulässige Ports
Telegram unterstützt nur vier Webhook-Ports. Während der Grund für diese Einschränkung derzeit unklar ist, kann er sich in Zukunft ändern. Derzeit unterstützte Ports sind:
- 443 (HTTPS wird empfohlen)
- 80
- 88
- 8443
Für den ordnungsgemäßen Betrieb des Webhooks muss einer dieser Ports verfügbar und zugänglich sein. Wenn Sie keinen Port explizit angeben, verwendet der Webhook standardmäßig Port 8443.
Servereinschränkungen
Da nur vier Ports zulässig sind, darf die Anzahl der Anwendungen, die Webhooks verwenden, vier auf demselben Server nicht überschreiten.
Voraussetzungen
Bevor Sie mit der Einrichtung beginnen, stellen Sie bitte sicher, dass Sie Folgendes haben:
- Node.js installiert: Wenn es noch nicht installiert ist, laden Sie Node.js von nodejs.org herunter und installieren Sie es.
- Telegram-Konto: Sie benötigen ein Telegram-Konto, um den Bot-Token zu erhalten und mit Ihrem Bot zu interagieren.
- Ngrok für HTTPS-URLs: Telegram erfordert Webhooks, um HTTPS-Endpunkte zu verwenden. Verwenden Sie Ngrok, um Ihren lokalen Server dem Internet zugänglich zu machen.
Der vollständige Code ist auf Github zu finden.
Telegram Webhook-Einstellungen (Node.js-Beispiel)
// 导入Telegram Bot API const TelegramBot = require('node-telegram-bot-api'); // 使用您的机器人令牌替换 const token = 'your telegram token'; // 请查看我的文章,了解如何在Telegram上从@BotFather获取机器人令牌 const WEB_HOOK_URL = 'https://localhost:3000/telegram-bot-webhook'; // 注意:它在localhost上无法工作,因此请使用ngrok之类的隧道服务。 // 创建使用Webhook的机器人 const bot = new TelegramBot(token, { webHook: { port: 88, // Telegram Webhook允许的端口:443、80、88、8443 }, }); // 初始化Webhook const initWebHook = async () => { const webhookInfo = await bot.getWebHookInfo(); if (webhookInfo.url !== WEB_HOOK_URL) { await bot.setWebHook(WEB_HOOK_URL, { max_connections: 100, }); } }; initWebHook(); // 监听任何消息 bot.on('message', (msg) => { const chatId = msg.chat.id; // 简单命令处理 if (msg.text.toLowerCase() === '/start') { bot.sendMessage(chatId, '欢迎!今天我能如何帮助您?', { reply_markup: { keyboard: [['/start', '/help']], }, }); } else if (msg.text.toLowerCase() === 'hello') { bot.sendMessage(chatId, `你好,${msg.from.first_name}!`); } else { bot.sendMessage(chatId, "我不确定如何回应。"); } }); // 导出机器人模块 module.exports = bot;
Telegram Webhook-Routing
const express = require("express"); const app = express(); const bot = require("./bot"); // 解析POST请求的JSON主体 app.use(express.json()); app.get("/", (req, res) => { res.send("Hello World"); }); app.post("/telegram-bot-webhook", (req, res) => { bot.processUpdate(req.body); res.sendStatus(200); }); app.listen(process.env.PORT || 3000, () => { console.log("服务器正在3000端口运行"); });
Zusammenfassung
Der Wechsel zu Webhooks kann Probleme mit der Begrenzung der Telegram-Rate beseitigen und Ihren Bot effizienter machen. Stellen Sie einfach sicher, dass Sie Ihren Server richtig konfigurieren, zulässige Ports verwenden und Ihre Verbindung mit HTTPS sichern.
Folgen Sie mir, um benachrichtigt zu werden, wenn mein nächster Artikel veröffentlicht wird?
Das obige ist der detaillierte Inhalt vonTelegramm-Webhook. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Häufig gestellte Fragen und Lösungen für das Ticket-Ticket-Ticket-Ticket in Front-End im Front-End-Entwicklungsdruck ist der Ticketdruck eine häufige Voraussetzung. Viele Entwickler implementieren jedoch ...

JavaScript ist der Eckpfeiler der modernen Webentwicklung. Zu den Hauptfunktionen gehören eine ereignisorientierte Programmierung, die Erzeugung der dynamischen Inhalte und die asynchrone Programmierung. 1) Ereignisgesteuerte Programmierung ermöglicht es Webseiten, sich dynamisch entsprechend den Benutzeroperationen zu ändern. 2) Die dynamische Inhaltsgenerierung ermöglicht die Anpassung der Seiteninhalte gemäß den Bedingungen. 3) Asynchrone Programmierung stellt sicher, dass die Benutzeroberfläche nicht blockiert ist. JavaScript wird häufig in der Webinteraktion, der einseitigen Anwendung und der serverseitigen Entwicklung verwendet, wodurch die Flexibilität der Benutzererfahrung und die plattformübergreifende Entwicklung erheblich verbessert wird.

Es gibt kein absolutes Gehalt für Python- und JavaScript -Entwickler, je nach Fähigkeiten und Branchenbedürfnissen. 1. Python kann mehr in Datenwissenschaft und maschinellem Lernen bezahlt werden. 2. JavaScript hat eine große Nachfrage in der Entwicklung von Front-End- und Full-Stack-Entwicklung, und sein Gehalt ist auch beträchtlich. 3. Einflussfaktoren umfassen Erfahrung, geografische Standort, Unternehmensgröße und spezifische Fähigkeiten.

Wie fusioniere ich Array -Elemente mit derselben ID in ein Objekt in JavaScript? Bei der Verarbeitung von Daten begegnen wir häufig die Notwendigkeit, dieselbe ID zu haben ...

JavaScript zu lernen ist nicht schwierig, aber es ist schwierig. 1) Verstehen Sie grundlegende Konzepte wie Variablen, Datentypen, Funktionen usw. 2) Beherrschen Sie die asynchrone Programmierung und implementieren Sie sie durch Ereignisschleifen. 3) Verwenden Sie DOM -Operationen und versprechen Sie, asynchrone Anfragen zu bearbeiten. 4) Vermeiden Sie häufige Fehler und verwenden Sie Debugging -Techniken. 5) Die Leistung optimieren und Best Practices befolgen.

Diskussion über die Realisierung von Parallaxe -Scrolling- und Elementanimationseffekten in diesem Artikel wird untersuchen, wie die offizielle Website der Shiseeido -Website (https://www.shiseeido.co.jp/sb/wonderland/) ähnlich ist ...

Zu den neuesten Trends im JavaScript gehören der Aufstieg von Typenkripten, die Popularität moderner Frameworks und Bibliotheken und die Anwendung der WebAssembly. Zukunftsaussichten umfassen leistungsfähigere Typsysteme, die Entwicklung des serverseitigen JavaScript, die Erweiterung der künstlichen Intelligenz und des maschinellen Lernens sowie das Potenzial von IoT und Edge Computing.

Eingehende Diskussion der Ursachen des Unterschieds in der Konsole.log-Ausgabe. In diesem Artikel wird die Unterschiede in den Ausgabeergebnissen der Konsolenfunktion in einem Code analysiert und die Gründe dafür erläutert. � ...
