iT邦幫忙

2021 iThome 鐵人賽

DAY 9
6

前一天我們講到綜合版可以接收所有種類的訊息。

@csrf_exempt
def callback(request):
    if request.method == 'POST':
        signature = request.META['HTTP_X_LINE_SIGNATURE']
        body = request.body.decode('utf-8')

        try:
            events = parser.parse(body, signature)  # 傳入的事件
        except InvalidSignatureError:
            return HttpResponseForbidden()
        except LineBotApiError:
            return HttpResponseBadRequest()

        for event in events:
            print("event", event.message.id)
            # print("event", type(event))
            if isinstance(event, MessageEvent):  # 如果有訊息事件
                print("message", event.message)
                message = []
                if event.message.type == 'text':
                    text_ = event.message.text
                    message.append(TextSendMessage(text=text_))

                elif event.message.type == 'sticker':
                    text_ = event.message.id
                    message.append(TextSendMessage(text=text_))

                elif event.message.type == 'image':
                    text_ = event.message.id
                    message.append(TextSendMessage(text=text_))

                elif event.message.type == 'video':
                    text_ = event.message.id
                    message.append(TextSendMessage(text=text_))

                elif event.message.type == 'audio':
                    text_ = event.message.id
                    message.append(TextSendMessage(text=text_))

                elif event.message.type == 'location':
                    text_ = event.message.id
                    message.append(TextSendMessage(text=text_))

                # 回復傳入的訊息文字
                line_bot_api.reply_message( event.reply_token, message )

            
        return HttpResponse()
    else:
        return HttpResponseBadRequest()

那我們先專心講解關於 type()text 的訊息

tyep == text

@csrf_exempt
def callback(request):
    if request.method == 'POST':
        signature = request.META['HTTP_X_LINE_SIGNATURE']
        body = request.body.decode('utf-8')

        try:
            events = parser.parse(body, signature)  # 傳入的事件
        except InvalidSignatureError:
            return HttpResponseForbidden()
        except LineBotApiError:
            return HttpResponseBadRequest()

        for event in events:
            print("event", event.message.id)
            # print("event", type(event))
            if isinstance(event, MessageEvent):  # 如果有訊息事件
                print("message", event.message)
                message = []
                if event.message.type == 'text':
                    text_ = event.message.text
                    message.append(TextSendMessage(text=text_))
                line_bot_api.reply_message( event.reply_token, message )
                
        return HttpResponse()
    else:
        return HttpResponseBadRequest()

我們在 line 19 宣告了一個 list,message 好讓我們之後 line_bot_api.reply_message() 推送訊息比較方便。

這邊跟之前一樣都沒有改過,就是回推送傳過的訊息。

那我們改成如果遇到關鍵字就傳送某些訊息的話...

from django.shortcuts import render

# Create your views here.

from django.shortcuts import render
from django.http import HttpResponse, HttpResponseBadRequest, HttpResponseForbidden
from django.views.decorators.csrf import csrf_exempt
from django.conf import settings

from linebot import LineBotApi, WebhookParser
from linebot.exceptions import InvalidSignatureError, LineBotApiError
from linebot.models import MessageEvent, TextSendMessage
import os

line_bot_api = LineBotApi(settings.LINE_CHANNEL_ACCESS_TOKEN)
parser = WebhookParser(settings.LINE_CHANNEL_SECRET)

@csrf_exempt
def callback(request):
    if request.method == 'POST':
        signature = request.META['HTTP_X_LINE_SIGNATURE']
        body = request.body.decode('utf-8')

        try:
            events = parser.parse(body, signature)  # 傳入的事件
        except InvalidSignatureError:
            return HttpResponseForbidden()
        except LineBotApiError:
            return HttpResponseBadRequest()

        for event in events:
            print("event", event.message.id)
            # print("event", type(event))
            if isinstance(event, MessageEvent):  # 如果有訊息事件
                print("message", event.message)
                message = []

                if event.message.type == 'text':
                    mtext = event.message.text
                    if "嗨" in mtext:
                        text_ = "哈囉你好"
                    else:
                        text_ = 'What?'

                    message.append(TextSendMessage(text=text_))


                # 回復傳入的訊息文字
                line_bot_api.reply_message( event.reply_token, message )

        return HttpResponse()
    else:
        return HttpResponseBadRequest()
if event.message.type == 'text':
    mtext = event.message.text
    if "嗨" in mtext:
        text_ = "哈囉你好"
    else:
        text_ = 'What?'

我們看一下 mtext 裡面有甚麼:

mtext: 嗨
mtext: 嗚嗚嗚
type of mtext: <class 'str'>

這裡我們可以看到 mtextstr 型態
所以這裡就可以透過邏輯運算來處理文字訊息。

當然,這裡其實都算是透過官版就可以處理的問題,我們明天就來看看基本的按鈕選項(Button Template)


補充

補充一個在 ngrok 連線時有可能發生的問題:

啟動 ngrok 連線卻出現以下錯誤:

Your account '' is limited to 1 similtaneous ngrok client session.
Active ngrok client sessions in region 'us':
    ......

ERR_NGROK_108

這段錯誤基本上是在說,帳戶只允許一個 client session。
附上官網傳送門

這邊自己的解決方式就只是換區而以:

ngrok http -region ap 8000

供大家參考參考


上一篇
【Day 08】基本程式介紹
下一篇
【Day 10】Button Template 應用
系列文
陪聊_伃時不候 Line Bot 聊天機器人30
圖片
  直播研討會
圖片
{{ item.channelVendor }} {{ item.webinarstarted }} |
{{ formatDate(item.duration) }}
直播中

尚未有邦友留言

立即登入留言