加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

php – 如何设置Telegram bot webhook?

发布时间:2020-12-13 13:42:08 所属栏目:PHP教程 来源:网络整理
导读:我正在开发一个Telegram机器人,我想将webhook设置为我的域名的URL.我已经在 Telegram’s guide之后生成了一个自签名证书.但是,我无法设置webhook.我搜索过以前的答案并找到了 this one,但它对我不起作用.谁能解释一下如何上传SSL证书并设置webhook? 我在服
我正在开发一个Telegram机器人,我想将webhook设置为我的域名的URL.我已经在 Telegram’s guide之后生成了一个自签名证书.但是,我无法设置webhook.我搜索过以前的答案并找到了 this one,但它对我不起作用.谁能解释一下如何上传SSL证书并设置webhook?
我在服务器上创建了一个文件,用于方便地设置电报webhook.

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

这应该在您希望运行Telegram Bot的同一台服务器上

<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>

>将此文件拖放到您希望托管机器人的同一台服务器上
>确保在Web服务器上启用.pem的mime-type
>浏览我们服务器上的此页面
>使用您的BOT_TOKEN填写表格并选择PORT
>上传您的证书文件
>提交表格

您将获得成功的结果:

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读