FlaskでLINE botを実装し、heroku上にdeployする
LINE botの実装に初挑戦し、[こちら]を参考にして進めております。
以下のapp.pyが、ローカル環境及びngrokで外部に公開した状態で実行できたところまでは確認できました。
しかしdeveloperでwebhook URLを登録しようとすると、以下のエラーが表示されてしまいます。
皆さんのお知恵をお借りしたいです…!
よろしくお願いします。
発生している問題・エラーメッセージ
The webhook returned an HTTP status code other than 200
該当のコード
python
1import os 2import sys 3from flask import Flask, request, abort 4 5from linebot import ( 6 LineBotApi, WebhookHandler 7) 8from linebot.exceptions import ( 9 InvalidSignatureError 10) 11from linebot.models import ( 12 MessageEvent, TextMessage, TextSendMessage, 13) 14 15app = Flask(__name__) 16 17# 下記password等は正しく入力しました 18line_bot_api = LineBotApi('') 19handler = WebhookHandler('') 20 21 22@app.route("/") 23def hello_world(): 24 return "hello world!" 25 26@app.route("/callback", methods=['POST']) 27def callback(request): 28 # get X-Line-Signature header value 29 signature = request.headers['X-Line-Signature'] 30 31 # get request body as text 32 body = request.get_data(as_text=True) 33 app.logger.info("Request body: " + body) 34 35 # handle webhook body 36 try: 37 handler.handle(body, signature) 38 except InvalidSignatureError: 39 abort(400) 40 41 return 'OK', 200 42 43# check-connect 44@app.route("/index", methods=['POST']) 45def index(): 46 return 'OK', 200 47 48@handler.add(MessageEvent, message=TextMessage) 49def handle_message(event): 50 if event.reply_token == "00000000000000000000000000000000": 51 return 'OK', 200 52 53 line_bot_api.reply_message( 54 event.reply_token, 55 TextSendMessage(text=event.message.text)), 200 56 57 58if __name__ == "__main__": 59 port = int(os.getenv("PORT")) 60 app.run(host="0.0.0.0",port=port) 61
試したこと
上記に加え、
herokuのログを確認し、指摘されたpythonのversion(現在は3.8.5)の問題は解決しました。
あなたの回答
tips
プレビュー