現在バイト先の勤怠管理システムを改善しようと、以下の動画を見て勤怠管理システムを作成中です。
参考動画→https://youtu.be/MHf6dideSqg
実現しようとしていることは、LINE上に出勤・退勤の文字を送信すると、グーグルスプレッドシート状にその文字が入力された時間を記載するというものです。このアプリはherokuにデプロイしようとしています。
作ったpythonファイルをheroku上にデプロイするまでは出来たのですが、heroku info --app<自分のアプリ>によって得られるWeb URLを表示しようとすると、application errorが発生してしまいます。参考動画では、1時間07分53秒当たりの作業になります。
原因を探るために,heroku logs --tail でログを確認すると、どんなに修正を加えても、h10のエラーが消えません。
もうかれこれ1週間くらい、止まったままですので、この場で質問させていただきました。
私は、完全にど素人なので経験者の皆様からみてエラーの原因と想定できる部分がありましたら、ご教授よろしくお願いいたします。
考えられるエラー原因は、以下を想定してます。
1.作成したファイルの中に、間違いがあり、エラー判定されている。
2.app.run(host = "0.0.0.0",port = port) の部分で誤りがある、どこかの記事でwindowsでは、host に"0.0.0.0"が使用できないと書いてあったので、これが現状エラーを起こしている原因ではないかと考えています。
実際に、ローカル環境(127.0.0.1など)であれば、hello worldという文字をブラウザ上に表示させることが出来るのですが、"0.0.0.0"を使用すると( このサイトにアクセスできません)という表示が出ます。
以下、私が実際に書いたコードになります。
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) 12 13import os 14 15app = Flask(__name__) 16 17YOUR_CHANNEL_ACCESS_TOKEN="MY_CHANNEL_ACCESS_TOKEN" 18YOUR_CHANNEL_SECRET="MY_CHANNEL_SECRET" 19 20line_bot_api = LineBotApi(YOUR_CHANNEL_ACCESS_TOKEN) 21handler = WebhookHandler(YOUR_CHANNEL_SECRET) 22 23@app.route("/") 24def hello_world(): 25 return "hello world" 26 27@app.route("/callback", methods=['POST']) 28def callback(): 29 # get X-Line-Signature header value 30 signature = request.headers['X-Line-Signature'] 31 32 # get request body as text 33 body = request.get_data(as_text=True) 34 app.logger.info("Request body: " + body) 35 36 # handle webhook body 37 try: 38 handler.handle(body, signature) 39 except InvalidSignatureError: 40 print("Invalid signature. Please check your channel access token/channel secret.") 41 abort(400) 42 43 return 'OK' 44 45@handler.add(MessageEvent, message=TextMessage) 46def handle_message(event): 47 line_bot_api.reply_message( 48 event.reply_token, 49 TextSendMessage(text=event.message.text)) 50 51 52if __name__ == "__main__": 53 port = os.getenv("PORT") 54 app.run(host="0.0.0.0",port = port)
Procfile
1web: python app.py
requirements.txt
1Flask 2line-bot-sdk 3pandas 4gspread 5oauth2client
runtime.txt
1python-3.9.4
後は、jsonファイルになります。jsonファイルは個人情報が多いので、とりあえず載せないで起きます。
計5つのファイルをpushした状態になります。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2022/04/01 12:33