python - 从 Viber 机器人向订阅用户发送消息

标签 python python-3.x flask bots viber

我正在尝试从 Viber 机器人向订阅用户发送消息。我可以获得订阅的用户 ID,但是当我发送消息时,出现 500 错误。

from flask import Flask, request, Response
from viberbot import Api
from viberbot.api.bot_configuration import BotConfiguration
from viberbot.api.messages.text_message import TextMessage

app = Flask(__name__)

viber = Api(BotConfiguration(
    name='PythonSampleBot',
    avatar='http://www.clker.com/cliparts/3/m/v/Y/E/V/small-red-apple-hi.png',
    auth_token='xxx-xxx-xxx'
))


@app.route('/', methods=['POST'])
def incoming():
    user_id = viber.get_account_info()['members'][0]['id']
    print(user_id)
    viber.send_messages(user_id, [
        TextMessage(text="thanks for subscribing!!!!!")
    ])
    return Response(status=200)


if __name__ == "__main__":
    context = ('E:\\Docs\\learn_py\\viberbot\\cert.pem',
               'E:\\Docs\\learn_py\\viberbot\\key.pem')
    app.run(host='0.0.0.0', port=4443, debug=True, ssl_context=context)

请求消息发送代码:

import json
import requests

webhook_url = 'https://xxx.xxx.xxx.xxx:4443'

requests.post(
    webhook_url, data=json.dumps({"text": "Hello World"}),
    headers={'Content-Type': 'application/json'},
    verify='E:\\Docs\\learn_py\\viberbot\\cert.pem'
)

错误信息:

Cfklv9HOJ6bXZcHMaTl9Gw==
192.168.1.1 - - [15/Mar/2019 08:44:02] "POST / HTTP/1.1" 500 - Traceback (most recent call last):   File "C:\Users\user\AppData\Local\Programs\Python\Python37\lib\site-packages\flask\app.py", line 2309, in __call__
    return self.wsgi_app(environ, start_response)   File "C:\Users\user\AppData\Local\Programs\Python\Python37\lib\site-packages\flask\app.py", line 2295, in wsgi_app
    response = self.handle_exception(e)   File "C:\Users\user\AppData\Local\Programs\Python\Python37\lib\site-packages\flask\app.py", line 1741, in handle_exception
    reraise(exc_type, exc_value, tb)   File "C:\Users\user\AppData\Local\Programs\Python\Python37\lib\site-packages\flask\_compat.py", line 35, in reraise
    raise value   File "C:\Users\user\AppData\Local\Programs\Python\Python37\lib\site-packages\flask\app.py", line 2292, in wsgi_app
    response = self.full_dispatch_request()   File "C:\Users\user\AppData\Local\Programs\Python\Python37\lib\site-packages\flask\app.py", line 1815, in full_dispatch_request
    rv = self.handle_user_exception(e)   File "C:\Users\user\AppData\Local\Programs\Python\Python37\lib\site-packages\flask\app.py", line 1718, in handle_user_exception
    reraise(exc_type, exc_value, tb)   File "C:\Users\user\AppData\Local\Programs\Python\Python37\lib\site-packages\flask\_compat.py", line 35, in reraise
    raise value   File "C:\Users\user\AppData\Local\Programs\Python\Python37\lib\site-packages\flask\app.py", line 1813, in full_dispatch_request
    rv = self.dispatch_request()   File "C:\Users\user\AppData\Local\Programs\Python\Python37\lib\site-packages\flask\app.py", line 1799, in dispatch_request
    return self.view_functions[rule.endpoint](**req.view_args)   File "E:\Docs\learn_py\viberbot\app.py", line 21, in incoming
    TextMessage(text="thanks for subscribing!!!!!")   File "C:\Users\user\AppData\Local\Programs\Python\Python37\lib\site-packages\viberbot\api\api.py", line 72, in send_messages
    to, self._bot_configuration.name, self._bot_configuration.avatar, message, chat_id)   File "C:\Users\user\AppData\Local\Programs\Python\Python37\lib\site-packages\viberbot\api\message_sender.py", line 27, in send_message
    return self._post_request(BOT_API_ENDPOINT.SEND_MESSAGE, payload)   File "C:\Users\user\AppData\Local\Programs\Python\Python37\lib\site-packages\viberbot\api\message_sender.py", line 53, in _post_request
    raise Exception(u"failed with status: {0}, message: {1}".format(result['status'], result['status_message'])) Exception: failed with status: 10, message: webhookNotSet  * Detected change in 'E:\\Docs\\learn_py\\viberbot\\app.py', reloading

更新:根据mingaleg的建议,我添加了viber.set_webhook('https://xxx.xxx.xxx.xxx:yyyy') incoming() 函数,现在出现另一个错误:

异常:失败,状态:1,消息:结果[HttpRequest[POST/HTTP/1.1]@2c67393 > HttpResponse[null 0 null]@72391ae] javax.net.ssl.SSLHandshakeException:一般 SSLEngine 问题

证书是按照 this answer 中的建议生成的:

openssl req -x509 -newkey rsa:4096 -keyout key.pem -out cert.pem -days 365

最佳答案

由于您有一个 webhookNotSet 错误消息,您应该将您的机器人配置为有一个:

...
viber = Api(BotConfiguration(
    name='PythonSampleBot',
    avatar='http://www.clker.com/cliparts/3/m/v/Y/E/V/small-red-apple-hi.png',
    auth_token='xxx-xxx-xxx'
))
viber.set_webhook(webhook_url)
...

webhook_url 应该是您的 flask 服务器可以访问的那个。

关于python - 从 Viber 机器人向订阅用户发送消息,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55177070/

相关文章:

python - 如何为不同的实现提取学习到的 ML 模型?

mongodb - PyMongo - 使用 connect=False 创建 MongoClient,或者在 fork 后创建客户端

python - 如果我同时使用各种类型的数据库,如何创建模型?

python - numpy 获取行和列索引二维数组的所有组合

python - 从 gurobipy 获取矩阵格式的约束

python - 使用 django-simple-captcha,当表单 is_valid 时为什么 human = True

python-3.x - 错误: No matching distribution found for Cython

python - 确认浏览器预取导致删除

python - 用户使用 Flask 生成的 Jinja 2 模板

python - 计算测地网格三角点的经纬度点(最好用python)