如何设置电报机器人网络钩子?设置网络钩子获取网络钩子

2022-08-30 18:54:11

我正在开发一个 Telegram 机器人,并且想要将 Webhook 设置为我域的 URL。我已经按照电报指南生成了一个自签名证书。但是,我无法设置网络钩子。我已经搜索了以前的答案并找到了这个答案,但它对我不起作用。任何人都可以解释我如何上传SSL证书并设置Webhook吗?


答案 1

设置网络钩子

https://api.telegram.org/bot{my_bot_token}/setWebhook?url={url_to_send_updates_to}

例如:

https://api.telegram.org/bot123456:ABC-DEF1234ghIkl-zyx57W2v1u123ew11/setWebhook?url=https://www.example.com

获取网络钩子

https://api.telegram.org/bot{my_bot_token}/getWebhookInfo

答案 2

我在服务器上创建了一个文件,以便方便地设置电报Webhook。

您可以在服务器上使用相同的文件。

这应该在您希望从中运行电报机器人的同一服务器上

<html>

<head>
  <title>Set Webhooks</title>
  <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css" />
  <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/bulma/0.6.0/css/bulma.min.css" />
  <script src="https://unpkg.com/vue/dist/vue.js"></script>
</head>

<body>
  <div class="container">
    <div id="app" class="section">
      <form :action="set_webhook" method="post" enctype="multipart/form-data">
        <label class="label">Enter your Token</label>
        <p class="control">
          <input class="input" type="text" v-model="token" />
        </p>
        <label class="label">Enter your Host</label>
        <p class="control">
          <input class="input" type="text" v-model="host" />
        </p>
        <label class="label">Enter your Port</label>
        <p class="control">
          <input class="input" type="text" v-model="port" />
        </p>

        <input type="hidden" name="url" v-model="bot_url">
        <label class="label">Maximum Connections?</label>
        <p class="control">
          <input class="input" type="text" name="max_connections" value="100" />
        </p>
        <br/>
        <p style="color:blue">{{ bot_url }}</p>
        <br/>
        <label class="label">Enter your Certificate</label>
        <p class="control">
          <input type="file" name="certificate" id="fileToUpload" />
        </p>
        <br/>
        <div class="control is-grouped">
          <p class="control">
            <button class="button is-primary" name="submit">Set Webhook</button>
          </p>
          <br/>
          <p class="control">
            <a :href="get_webhook_info" target="_blank" class="button is-info">Get Webhook Info</a>
          </p>
        </div>
    </div>
  </div>
  <script>
    new Vue({
      el: '#app',
      data: {
        token: 'xxx',
        port: 88,
        host: 'your-server.com',
      },
      computed: {
        get_webhook_info: function () {
          return 'https://api.telegram.org/bot' + this.token + '/getwebhookinfo'
        },
        set_webhook: function () {
          return 'https://api.telegram.org/bot' + this.token + '/setwebhook'
        },
        bot_url: function () {
          return 'https://' + this.host + ':' + this.port + '/' + this.token
        }
      }
    }

    )
  </script>
</body>

</html>
  1. 将此文件放在要托管机器人的同一台服务器上
  2. 确保在 Web 服务器上启用了 的 mime 类型.pem
  3. 浏览到我们服务器上的此页面
  4. 在表格中填写您的BOT_TOKEN和所选端口
  5. 上传证书文件
  6. 提交表格

您将获得成功的结果:

{"ok":true,"result":true,"description":"Webhook was set"}

enter image description here


推荐