超簡単PythonでLINE BOT入門(おうむ返し)Google App Engine利用
Pythonで超簡単におうむ返しLine Bot作成(Google App Engine利用)
1. LINE Developersへ行ってプロバイダー作成&Messaging APIチャネル作成
2. アクセストークン再発行
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設定
Webhook送信は利用するに設定
Webhook URLにはhttps://[YOUR_PROJECT_ID].appspot.com/callbackを設定
6. 確認
LINE Developersのチャネル基本設定>Bot情報のQRコードをLINEで友達追加
以上、超簡単!
7. トラブルシューティング
自動応答メッセージをOFFにするには、LINE Developersのチャネル基本設定>自動応答メッセージ>設定はこちらから
詳細設定>応答メッセージをオフに