我已在电报机器人上设置机器人,并通过应用程序脚本将其与谷歌电子表格连接,方法是按照this教程。这是代码:
var token = ""; // FILL IN YOUR OWN TOKEN
var telegramUrl = "https://api.telegram.org/bot" + token;
var webAppUrl = ""; // FILL IN YOUR GOOGLE WEB APP ADDRESS
var ssId = ""; // FILL IN THE ID OF YOUR SPREADSHEET
function getMe() {
var url = telegramUrl + "/getMe";
var response = UrlFetchApp.fetch(url);
Logger.log(response.getContentText());
}
function setWebhook() {
var url = telegramUrl + "/setWebhook?url=" + webAppUrl;
var response = UrlFetchApp.fetch(url);
Logger.log(response.getContentText());
}
function sendText(id,text) {
var url = telegramUrl + "/sendMessage?chat_id=" + id + "&text=" + text;
var response = UrlFetchApp.fetch(url);
Logger.log(response.getContentText());
}
function doGet(e) {
return HtmlService.createHtmlOutput("Hi there");
}
function doPost(e) {
// this is where telegram works
var data = JSON.parse(e.postData.contents);
var text = data.message.text;
var id = data.message.chat.id;
var name = data.message.chat.first_name + " " + data.message.chat.last_name;
var answer = "Hi " + name + ", thank you for your comment " + text;
sendText(id,answer);
SpreadsheetApp.openById(ssId).getSheets()[0].appendRow([new Date(),id,name,text,answer]);
if(/^@/.test(text)) {
var sheetName = text.slice(1).split(" ")[0];
var sheet = SpreadsheetApp.openById(ssId).getSheetByName(sheetName) ? SpreadsheetApp.openById(ssId).getSheetByName(sheetName) : SpreadsheetApp.openById(ssId).insertSheet(sheetName);
var comment = text.split(" ").slice(1).join(" ");
sheet.appendRow([new Date(),id,name,comment,answer]);
}
}
现在我遇到了以下问题;我使用我的机器人来存储来自家庭自动化系统的消息。因此,我通过HTTP GET请求将这些消息从系统发送到电报机器人:
目前,通过http get请求发送的这些消息似乎被脚本忽略。 anyoene知道如何解决这个问题吗?
答案 0 :(得分:1)
从您的问题和评论来看,您似乎正在努力将信息从脚本发送到Telegram上的机器人。这是执行此操作的步骤:
1.- 创建机器人:在Telegram的搜索中查找@BotFather。单击开始,编写/ newbot,并为其命名和用户名。您应该获得一个令牌来访问HTTP API。保存此令牌。
2.- 在Telegram上使用其用户名找到您的机器人。给它写一些东西,例如'测试'。稍后会派上用场。
3.- 从您的代码对机器人的测试访问
var token = "123456:kioASDdjicOljd_ijsdf"; // Fill this in with your token
var telegramUrl = "https://api.telegram.org/bot" + token;
function getMe() {
var url = telegramUrl + "/getMe";
var response = UrlFetchApp.fetch(url);
Logger.log(response.getContentText());
}
您应该得到类似以下内容的东西:
{"ok":true,"result":{"id":<somenumber>,"is_bot":true,"first_name":"<name of your bot>","username":"<username of your bot>","can_join_groups":true,"can_read_all_group_messages":false,"supports_inline_queries":false}}
4.-编写 sendMessage 函数
function sendMessage(chat_id,text) {
var url = telegramUrl + "/sendMessage?chat_id=" + chat_id + "&text=" + text;
var response = UrlFetchApp.fetch(url);
Logger.log(response.getContentText());
}
您要发送的已知文本,例如“测试机器人”,但chat_id未知。我们从哪里得到的?
5.- 找到chat_id 。在运行此功能之前,请确保至少已在Telegram上向机器人写入了一条消息(步骤2)
function getChat_id(){
var res = UrlFetchApp.fetch(telegramUrl+"/getUpdates").getContentText();
var res = JSON.parse(res);
Logger.log(res.result[0].message.chat.id.toString());
}
6.- 使用在步骤5中找到的chat_id和要发送的消息运行sendMessage 。