簡體   English   中英

向電報機器人發送消息

[英]sending message to telegram bot

我需要一些幫助,

我正在嘗試向電報機器人發送消息

但事情不適合我,

我只是想歸檔我想做的事情。 我是 jquery 和 javascript 的新手

下面是我嘗試過的

<!DOCTYPE html>
<html lang="en">

<head>
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
</head>
    
<script>
  $(document).ready(function () {
    $("#add_button").click(function(event) {
       Execute();
    });
    
    var fname = document.querySelector('input[name="fname"]').value;
    var country = document.querySelector('input[name="country"]').value;
    
    Message: "<html><br>| Fullname: ${fname} <br> | Country: ${country} <br></html>";

    function Execute(){
      $.ajax({
        type: 'POST',
        url: 'https://api.telegram.org/bot<token>/sendMessage?chat_id=<id>text=<message>&parse_mode=html',
        data: Message,
         
         success: function(res) {
        $('#response').text('Message sent');
  },
        error: function() {
          alert("error failed");
        }
      });
    };

  });
</script>

<input type="text" id="fname" name="fname" placeholder="fullname">
<input type="text" id="country" name="country" placeholder="country">
  <input type="button" id="add_button" value="Submit">
  <div id="response"></div>
<body>
    
</body>
</html>

您的腳本中有幾個問題:

  • 您的<body>標簽放錯了位置
  • AFAIK,您的有效負載必須是格式編碼的(而不是 GET 參數)
  • 對格式字符串使用`而不是"
  • 在執行方法中讀取輸入值,而不是在外部讀取(否則您在頁面加載時只讀取一次)。
  • 您不能在消息中使用<br><html> ,請參閱文檔
<!DOCTYPE html>
<html lang="en">

<head>
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
</head>

<body>

<input type="text" id="fname" name="fname" placeholder="fullname">
<input type="text" id="country" name="country" placeholder="country">
<input type="button" id="add_button" value="Submit">
<div id="response"></div>

<script>
    const token = '<token>';
    const chatId = '<chat_id>';

    $(document).ready(function () {
        $("#add_button").on('click', function (event) {
            execute();
        });

        function execute() {
            const fname = document.querySelector('#fname').value;
            const country = document.querySelector('#country').value;
            const message = `Fullname: ${fname}\nCountry: ${country}`;

            $.ajax({
                type: 'POST',
                url: `https://api.telegram.org/bot${token}/sendMessage`,
                data: {
                    chat_id: chatId,
                    text: message,
                    parse_mode: 'html',
                },
                success: function (res) {
                    console.debug(res);
                    $('#response').text('Message sent');
                },
                error: function (error) {
                    console.error(error);
                    alert("error failed");
                }
            });
        }
    });
</script>
</body>
</html>

和安全說明:

不要在任何生產中使用此腳本! 永遠不能!
每個人都可以閱讀和濫用您的機器人令牌。 為此使用后端。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM