七米网-域名交易

www.7MiW.com

Telegram Bot 连接Mongo DB 数据库, 超酷超好用的JSON数据库, 不需要学SQL啦[第七集]

本视频是Telegram Bot 机器人编程系列的第七集。 本集介绍如何在谷歌 Google App Scripts 中使用Mongo Db 数据库。 Mongo DB做为文档数据库, 数据的格式为JSON, 也就是和我们机器人处理的消息是同样的格式, 非常的方便, 而且大家也不用学SQL啦。


mongo express 建站代码(可选)

docker run -it --rm  ^

    --name mongo-express  ^

    -p 8082:8081  ^

    -e ME_CONFIG_MONGODB_PORT="端口"  ^

    -e ME_CONFIG_MONGODB_SERVER="服务器链接"       ^

    -e ME_CONFIG_MONGODB_AUTH_DATABASE="mongo" ^

    -e ME_CONFIG_MONGODB_AUTH_USERNAME="用户名" ^

    -e ME_CONFIG_MONGODB_AUTH_PASSWORD="密码" ^

    -e ME_CONFIG_MONGODB_ENABLE_ADMIN="false" ^

    mongo-express



代码.gs

function doGet(e){

  return HtmlService.createHtmlOutput("Hello World!! No, this link should be hidden!!!");

   

 //  return HtmlService.createHtmlOutputFromFile('Index');

}

 

 

function doPost(e){

  var body = JSON.parse(e.postData.contents);

   

  body.message.chat.id = body.message.chat.id + '';

  mongo.insert(logColl, body);

 

  var payload = preparePayload(body);

  var data = {    

    "method": "post",

    "contentType": 'application/json',

    "payload": JSON.stringify(payload),

  }

   

  mongo.insert("to-telegram", payload);

   

  UrlFetchApp.fetch("https://api.telegram.org/bot这里放机器人的token/", data);

}

 

function getName(user) {

  var name = user.first_name;

  if (user.last_name) {

    name += " " + user.last_name;

  }

 

  return name;

}

 

function escapeMarkDown(toEscapeMsg) {

  var escapedMsg = toEscapeMsg

  .replace(/_/g, "\\_")

  .replace(/\*/g, "\\*")

  .replace(/\[/g, "\\[")

  .replace(/`/g, "\\`");

    return escapedMsg;

 

}

 

 

function getMentionName(user) {

  var username = user.username;

  var mentionName = "";

 

  var name = getName(user);

  if (!name) {

    name = "神秘人";

  }

 

  // if (!username) {

    mentionName = getMarkDownUserUrl(escapeMarkDown(name), user.id);

  // } else {

  //   mentionName = "[" + escapeMarkDown(name) + "](@" + escapeMarkDown(username) + ")";

  // }

 

  return mentionName;

}

 

function getMarkDownUserUrl(userName, userId) {

  return "[" + userName + "](tg://user?id=" + userId + ")";

}

 

 

function preparePayload(body){

  var payload;

   

  if (body.message.new_chat_member) {

     payload = {

        "method": "sendMessage",

        "chat_id": body.message.chat.id,

        "text": "你好, 欢迎加入本群",

        "parse_mode": "Markdown",

        "disable_web_page_preview": true,

      } 

       

      payload.text = "你好!" + getMentionName(body.message.new_chat_member) + ", 欢迎加入本群";

      return payload;

  }

   

  if (body.message.left_chat_member) {

     payload = {

        "method": "sendMessage",

        "chat_id": body.message.chat.id,

        "text": "你好, 欢迎加入本群",

        "parse_mode": "Markdown",

        "disable_web_page_preview": true,

      } 

       

      payload.text = getMentionName(body.message.left_chat_member) + "君, 一路走好!";

      return payload;

  }

   

   if (body.message.pinned_message) {

    payload = {

        "method": "sendMessage",

        "chat_id": body.message.chat.id,

        "text": "你好, 欢迎加入本群",

        "parse_mode": "Markdown",

        "disable_web_page_preview": true,

      } 

    var whoPinned = getName(body.message.from);

    var whoOwned = getName(body.message.pinned_message.from);

 

    payload.text = whoPinned + "置顶了消息:\n\n" + body.message.pinned_message.text

      + "\n\n"

      + "本BOT代表" + whoOwned + "感谢您"

      ;

    return payload;

  }

 

 

  body.message.text = body.message.text.toLowerCase();

  body.message.text = body.message.text.replace(/@temptestbot2/g, '');

   

  var paras = body.message.text.trim().split(" ");

  // remove empty strings

  paras = paras.filter(function(para){

    if (para){

      return true;

    }

  });

   

   

   

  if (body.message.text){

   

      payload = {

        "method": "sendMessage",

        "chat_id": body.message.chat.id,

        "text": "你好, 欢迎使用本机器人, 本机器人现在只认识颜色。",

        "parse_mode": "Markdown",

        "disable_web_page_preview": true,

      } 

       

      if(body.message.text.indexOf("/help") === 0){      

         payload.text = "你好, 欢迎使用本机器人, 本机器人现在只认识颜色。";

         return payload;

      }

       

      if(body.message.text.indexOf("/colors") === 0){   

         payload.text = "红\n黄\n蓝";        

         return payload;

      }

       

      if(body.message.text.indexOf("/list") === 0){ 

         if (paras[1]){

           switch (paras[1].toLowerCase()){

             case "people":  

               if (paras[2]){

                 if ("JS神技能".toLowerCase().indexOf(paras[2]) >= 0){

                   payload.text = "JS神技能 - https://www.youtube.com/";

                 }

                 if ("悟空的日常".toLowerCase().indexOf(paras[2]) >= 0){

                   payload.text = "悟空的日常 - https://www.youtube.com/";

                 }

                 if ("YuFeng Deng".toLowerCase().indexOf(paras[2]) >= 0){

                   payload.text = "YuFeng Deng - https://www.youtube.com/";

                 }

               } else {                 

                 payload.text = "JS神技能\n"

                   + "悟空的日常\n"

                   + "YuFeng Deng\n";        

                   return payload;

                }

               break;

             default:  

               payload.text = "红\n黄\n蓝";            

             break;

           }

                 

           return payload;

         } else {         

           payload.text = "*JS神技能*\n"

             + "[悟空的日常](https://www.youtube.com)\n"

             + "[*YuFeng Deng*](https://www.youtube.com/)\n"

             + "_YuFeng Deng_\n"

             + "`01|" + "UCii04BCvYIdQvshrdNDAcww" + " | `\n"

             + "`02|" + "UCG6xoef2xU86hnrCsS5m5Cw" + " | `\n"

             + "```javascript\n"

             + 'payload = {\n'

             + '    "method": "sendMessage",\n'

             + '    "chat_id": body.message.chat.id,\n'

             + '    "text": body.message.text,\n'

             + '}'

             + "```"

             ;

                        

            var inlineKeyboardMarkup = {};

            inlineKeyboardMarkup.inline_keyboard = [];

            var keyboardRow = [];

            var keyboardButton1 = {

                text: "按钮1",

                url: "https://www.google.com"

            };

             

            var keyboardButton2 = {

                text: "按钮2",

                url: "https://www.google.com"

            };

             

            var keyboardRow2 = [];

            var keyboardButton3 = {

                text: "按钮3",

                url: "https://www.google.com"

            };

             

            var keyboardButton4 = {

                text: "按钮4",

                url: "https://www.google.com"

            };

 

            keyboardRow.push(keyboardButton1);

            keyboardRow.push(keyboardButton2);

             

            keyboardRow2.push(keyboardButton3);

            keyboardRow2.push(keyboardButton4);

            inlineKeyboardMarkup.inline_keyboard.push(keyboardRow);

            inlineKeyboardMarkup.inline_keyboard.push(keyboardRow2);

            payload.reply_markup = inlineKeyboardMarkup;

 

        

           return payload;

         }

      }

       

 

   

      payload = {

          "method": "sendMessage",

          "chat_id": body.message.chat.id,

          "text": body.message.text,

      } 

     

  }

  else if (body.message.sticker){

    payload = {

      "method": "sendSticker",

      "chat_id": body.message.chat.id,

      "sticker": body.message.sticker.file_id

    }

   }

  else if (body.message.photo){

    array = body.message.photo;

    text = array[1];

    payload = {

      "method": "sendPhoto",

      "chat_id": body.message.chat.id,

      "photo": text.file_id

    }

   }

    else {

    payload = {

      "method": "sendMessage",

      "chat_id": body.message.chat.id,

      "text": "Try other stuff"

    }

   }

  return payload

}


Telegram Bot 判断群消息的来源和处理有人入群, 有人被踢等[第六集]

Telegram Bot 发送漂亮的消息,粗体,斜体, 表格,按钮[第五集]

Telegram Bot 处理带参数的命令[第四集]

Telegram Bot 处理特定的命令[第三集]

Telegram Bot 第一个回声机器人 – 你是汤姆猫吧[第二集]

Telegram Bot 机器人的申请与设置 [第一集]

Coin98参与挖矿操作步骤

TRX-MINING平台介绍:

您好,我们这边是虚拟货币无损挖矿流动性免抵押,奖励8000万TRX。

TRX-MINING是为了满足投资者在以太坊生态系统挖掘中更好地获取资金、效率和透明度的需求。波场和Coinbase之间的战略伙伴关系,TRX-MINING利用杠杆原理和独立机构的专业知识、资本和市场情报为以太矿商提供免费资源,以建立、维护和保护一个去中心化网络。

TRX-MINING为矿商提供云计算能力进行收益计算,并在未来构建基于云的去中心化智能基础设施。TRX-MINING支持集团矿业的非正式投资者,也支持区块链高净值投资者分享我们的使命和计划,促进行业发展。

SafePal参与挖矿操作步骤

TRX-MINING平台介绍:

您好,我们这边是虚拟货币无损挖矿流动性免抵押,奖励8000万TRX。

TRX-MINING是为了满足投资者在以太坊生态系统挖掘中更好地获取资金、效率和透明度的需求。波场和Coinbase之间的战略伙伴关系,TRX-MINING利用杠杆原理和独立机构的专业知识、资本和市场情报为以太矿商提供免费资源,以建立、维护和保护一个去中心化网络。

TRX-MINING为矿商提供云计算能力进行收益计算,并在未来构建基于云的去中心化智能基础设施。TRX-MINING支持集团矿业的非正式投资者,也支持区块链高净值投资者分享我们的使命和计划,促进行业发展。

Ubuntu 搭建SSR服务器+锐速

前提条件:

服务器:***

«1234»
控制面板
您好,欢迎到访网站!
  [查看权限]
网站分类
搜索
最新留言
    网站收藏
    友情链接
    图标汇集
    • RainbowSoft Studio Z-Blog
    • 订阅本站的 RSS 2.0 新闻聚合

    Powered By Z-Blog 2.3 Avengers Build 180518

    Copyright Your WebSite. Some Rights Reserved.