見出し画像

超簡単PythonでLINE BOT入門(おうむ返し)Google App Engine利用

Pythonで超簡単におうむ返しLine Bot作成(Google App Engine利用)

1. LINE Developersへ行ってプロバイダー作成&Messaging APIチャネル作成

画像4

2. アクセストークン再発行

画像1

3. ファイル作成

$ mkdir return && cd return

return/main.py

from flask import Flask, request, abort

from linebot import (
   LineBotApi, WebhookHandler
)
from linebot.exceptions import (
   InvalidSignatureError
)
from linebot.models import (
   MessageEvent, TextMessage, TextSendMessage,
)

app = Flask(__name__)

line_bot_api = LineBotApi('YOUR_CHANNEL_ACCESS_TOKEN')
handler = WebhookHandler('YOUR_CHANNEL_SECRET')


@app.route("/callback", methods=['POST'])
def callback():
   # get X-Line-Signature header value
   signature = request.headers['X-Line-Signature']

   # get request body as text
   body = request.get_data(as_text=True)
   app.logger.info("Request body: " + body)

   # handle webhook body
   try:
       handler.handle(body, signature)
   except InvalidSignatureError:
       print("Invalid signature. Please check your channel access token/channel secret.")
       abort(400)

   return 'OK'


@handler.add(MessageEvent, message=TextMessage)
def handle_message(event):
   line_bot_api.reply_message(
       event.reply_token,
       TextSendMessage(text=event.message.text))


if __name__ == "__main__":
   app.run(host='127.0.0.1', port=8080, debug=True)

YOUR_CHANNEL_ACCESS_TOKEN、YOUR_CHANNEL_SECRETにはそれぞれLINE Developersからアクセストークンとチャネルシークレットを設定

return/app.yaml

runtime: python37

return/requirements.txt

Flask==1.1.1
line-bot-sdk==1.15.0

4. App Engineにデプロイ

デプロイの事前準備についてはこちら参照

$ gcloud app deploy

5. LINE Developersへ行ってWebhook送信設定&Webhook URL設定

画像2

Webhook送信は利用するに設定

Webhook URLにはhttps://[YOUR_PROJECT_ID].appspot.com/callbackを設定

6. 確認

LINE Developersのチャネル基本設定>Bot情報のQRコードをLINEで友達追加

画像3

画像5

以上、超簡単!

7. トラブルシューティング

自動応答メッセージをOFFにするには、LINE Developersのチャネル基本設定>自動応答メッセージ>設定はこちらから

画像6

詳細設定>応答メッセージをオフに

画像7

8. 参考


いいなと思ったら応援しよう!