🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

1回答

1086閲覧

lineDevelopersのwebhookにエラーが出ます。

退会済みユーザー

退会済みユーザー

総合スコア0

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2019/10/01 14:38

編集2019/10/02 11:09

イメージ説明

実現したい事

Lineのapiを使用してオウム型のボットを作成しています。

発生している問題・エラーメッセージ

現状はherokuまでのデプロイはできているのですが、いざボットにメッセージを送って見ると返信が来ません(自動応答のメッセージは来る)。webhookに接続する際に「Webhookが無効なHTTPステータスコードを返しました(期待されるステータスコードは200です)」というエラーが出ているので、ここが原因かなと踏んでいます。ちなみに、heroku logsでエラー内容を確認すると503(サーバーに関するエラー)と出ます。ネットで調べるとwebhookのエラーは機能には関係ないと書かれてるものもありますが、正直ここ以外に原因の検討がつきません。
上記エラーの解決方法がわかる方、知恵をお貸し頂けないでしょうか?

該当のソースコード

Python

1from flask import Flask, request, abort 2 3from linebot import ( 4 LineBotApi, WebhookHandler 5) 6from linebot.exceptions import ( 7 InvalidSignatureError 8) 9from linebot.models import ( 10 MessageEvent, TextMessage, TextSendMessage, 11) 12import os 13 14app = Flask(__name__) 15 16 17YOUR_CHANNEL_ACCESS_TOKEN = os.environ["LantpFiJX9Ja24IZkkHigDI2bv\ 183S38JOmgFxAN7jxRY1ZaFsY\ 19bceLhLaVENrqatHz+SzTylw\ 20M1WniLT/Q01h5hprJzzIYlw\ 21KlF4Vg/7MYGHt9LqdZhbF8Ng\ 22fCe0k478GRxU13rJ5IWxQcj3QDx\ 23GL2QdB04t89/1O/w1cDnyilFU="] 24YOUR_CHANNEL_SECRET = os.environ["5cc2db76678a82e1454416e7aba39422"] 25 26line_bot_api = LineBotApi(YOUR_CHANNEL_ACCESS_TOKEN) 27handler = WebhookHandler(YOUR_CHANNEL_SECRET) 28 29 30@app.route("/callback", methods=['POST']) 31def callback(): 32 33 signature = request.headers['X-Line-Signature'] 34 35 body = request.get_data(as_text=True) 36 app.logger.info("Request body: " + body) 37 38 try: 39 handler.handle(body, signature) 40 except InvalidSignatureError: 41 abort(400) 42 43 return 'OK' 44 45 46@handler.add(MessageEvent, message=TextMessage) 47def handle_message(event): 48 line_bot_api.reply_message( 49 event.reply_token, 50 TextSendMessage(text=event.message.text)) 51 52 53if __name__ == "__main__": 54 port = int(os.getenv("PORT", 5000)) 55 app.run(host="0.0.0.0", port=port)

試したこと

main.pyの文法エラーの訂正。
環境変数の再設定。
app = Flask(name)の下にapp.debug = Falseを追加。

ここに問題に対して試したことを記載してください。

補足情報(FW/ツールのバージョンなど)

エディタはpycharmです。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

FiroProchainezo

2019/10/02 05:46

出ているログを、編集しないで、そのままの状態で全文載せる事はできますか?
退会済みユーザー

退会済みユーザー

2019/10/02 11:11

ご返信ありがとうございます! はい!ただ今エラーログの画像を添付致しました。 ご確認よろしくお願いします。
退会済みユーザー

退会済みユーザー

2019/10/07 04:24 編集

エラーログの全文はこちらです。 2019-10-01T22:22:47.000000+00:00 app[api]: Build succeeded 2019-10-01T22:22:50.620244+00:00 heroku[web.1]: Starting process with command `python main.py` 2019-10-01T22:22:54.421023+00:00 heroku[web.1]: State changed from starting to crashed 2019-10-01T22:22:54.398756+00:00 heroku[web.1]: Process exited with status 1 2019-10-01T22:22:54.286815+00:00 app[web.1]: Traceback (most recent call last): 2019-10-01T22:22:54.286849+00:00 app[web.1]: File "main.py", line 24, in <module> 2019-10-01T22:22:54.287111+00:00 app[web.1]: GL2QdB04t89/1O/w1cDnyilFU="] 2019-10-01T22:22:54.287117+00:00 app[web.1]: File "/app/.heroku/python/lib/python3.6/os.py", line 669, in __getitem__ 2019-10-01T22:22:54.287805+00:00 app[web.1]: raise KeyError(key) from None 2019-10-01T22:22:54.287844+00:00 app[web.1]: KeyError: 'LantpFiJX9Ja24IZkkHigDI2bv3S38JOmgFxAN7jxRY1ZaFsYbceLhLaVENrqatHz+SzTylwM1WniLT/Q01h5hprJzzIYlwKlF4Vg/7MYGHt9LqdZhbF8NgfCe0k478GRxU13rJ5IWxQcj3QDxGL2QdB04t89/1O/w1cDnyilFU=' 2019-10-01T22:23:09.440811+00:00 heroku[router]: at=error code=H10 desc="App crashed" method=POST path="/callback" host=kento.herokuapp.com request_id=3dffcba8-b177-4878-a2a6-904066ecbaa9 fwd="147.92.149.168" dyno= connect= service= status=503 bytes= protocol=https 2019-10-01T22:24:38.293599+00:00 heroku[router]: at=error code=H10 desc="App crashed" method=POST path="/callback" host=kento.herokuapp.com request_id=25c657fd-3436-4784-8ec3-07333169cca9 fwd="203.104.156.74" dyno= connect= service= status=503 bytes= protocol=https 2019-10-01T22:24:55.739559+00:00 heroku[router]: at=error code=H10 desc="App crashed" method=POST path="/callback" host=kento.herokuapp.com request_id=1ba5cb83-e82a-40d7-8032-d04d24f041ac fwd="203.104.156.74" dyno= connect= service= status=503 bytes= protocol=https (venv) (base) Apple-no-MacBook-Pro:data apple$ heroku login heroku: Press any key to open up the browser to login or q to exit: Opening browser to https://cli-auth.heroku.com/auth/browser/93516943-fd62-4d55-ab57-a14dfb140ee0 Logging in... done Logged in as k000000@gmail.com
guest

回答1

0

keyがNone、KeyErrorと書いてあるので、以下の部分のkeyがないのでは?

2019-10-01T22:22:54.287805+00:00 app[web.1]: raise KeyError(key) from None 2019-10-01T22:22:54.287844+00:00 app[web.1]: KeyError: 'LantpFiJX9Ja24IZkkHigDI2bv3S38JOmgFxAN7jxRY1ZaFsYbceLhLaVENrqatHz+SzTylwM1WniLT/Q01h5hprJzzIYlwKlF4Vg/7MYGHt9LqdZhbF8NgfCe0k478GRxU13rJ5IWxQcj3QDxGL2QdB04t89/1O/w1cDnyilFU='

投稿2019/10/03 02:02

FiroProchainezo

総合スコア2421

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2019/10/03 02:35

やはりキーに関してぽいですよね。。。一応、herokuの方にもアクセスキーなどを設定しているのですが、再度試してみます。最初から作り直すのもありかなと考えてます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.36%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問