###### tags: `FM611A` `LINE` `Bot`
# FM611A Lab06 LINE 聊天機器人版
在〈[MQTT 版 Lab 06 語音聲控電源插座實作教學](/IsNCFSBqQMOlppZIx4r31g)〉一文刊出後, 有讀者提出『那是不是可以用 LINE 訊息來控制繼電器開關呢?』, 其實只要建立起 MQTT 的通道, 任何可以連上 MQTT 伺服器的裝置或程式都可以相互通訊, 作法其實就跟同一產品內的 Lab04、Lab05 介紹的 LINE 聊天機器人類似, 以下我們就帶大家一步步實作囉。
## LINE 聊天機器人簡介
LINE 聊天機器人的介紹可以參考套件手冊上的說明, 主要就是 LINE 伺服器會將使用者透過 LINE App 鍵入的訊息轉送給我們自己要撰寫的後端程式, 在後端程式中依據收到的訊息內容決定對應的執行工作, 並且產生回應訊息:
```graphviz
digraph hierarchy {
nodesep=1.0 // increases the separation between nodes
node [color=Red,fontname=Courier,shape=box] //All nodes will this shape and colour
edge [color=Blue, style=dashed] //All the lines look like this
b[label="後端程式"]
l[label="LINE 伺服器"]
a[label="LINE App"]
a->l [label="① 使用者發送訊息"]
l->a [label="④ 轉送回應"]
l->b [label="② 轉送訊息"]
b->l [label="③ 後端程式產生的回應"]
{rank=same;b l a} // Put them on the same level
}
```
以我們的例子來說, 就是要在後端程式中判斷使用者訊息是否有包含『打開』、『開燈』、『關閉』、『關燈』這樣的內容, 據此發送訊息到 MQTT 伺服器上, 這樣控制板端的程式就可以從 MQTT 接收訊息控制繼電器開關了。
在繼續往下實作前, 請先依照〈[MQTT 版 Lab 06 語音聲控電源插座實作教學](/IsNCFSBqQMOlppZIx4r31g)〉一文的說明, **[註冊 AIO 帳號並建立 voice 資料通道](https://hackmd.io/IsNCFSBqQMOlppZIx4r31g#%E7%94%B3%E8%AB%8B-AIO-%E5%B8%B3%E8%99%9F)**。
## 建立 LINE 聊天機器人
要建立 LINE 聊天機器人, 第一步就是要到 LINE 開發人員專區註冊登入後, 利用網頁介面建立 **Message API** 的資料通道:
1. 請開啟瀏覽器連線至 https://developers.line.biz/ 進入 LINE 開發人員頁面, 按右上角的 **Log in** 登入:

按一下**使用LINE帳號登入**

填入你在 LINE 註冊的電子郵件與密碼:

:::info
如果忘記密碼, 可以有兩種方式解決:
1. 在手機的 LINE App 中, 進入『**設定/我的帳號/密碼**』重新設定密碼。
2. 使用同一頁面下方的**透過行動條碼登入**, 即可以手機的 LINE App 掃描 QR code 登入。
:::
請依照畫面指示, 到 LINE App 上填入確認數字後登入:

1. 請在 **Providers** 旁按 **Create**:

填入自訂的名稱後按 **Create** 建立:

1. 往下捲按 **Create Message API Channel** 建立聊天機器人類型的資料通道:

往下捲動依照下圖填入各欄位資料, 務必勾選同意授權條款後按 **Create** 建立:

按 **OK** 確認:

按**同意**完成:

1. 切換到 **Message API** 頁次:

往下捲找到 **Channel access token** 後按 **Issue**:

這會產生可以和此聊天機器人溝通的**存取權杖**, 後端程式必須使用此存取權杖才能處理聊天機器人的訊息。按右邊的小按鈕可以複製存取權杖:

請保留此網頁不要關閉, 以便稍後複製權杖。
## 後端程式
後端程式就如同產品的 Lab04 與 Lab05, 會使用 Google Apps Script 撰寫的網頁應用程式, 請如下一一完成:
1. 請開啟新的網頁連線至 https://www.google.com/script/start/, 按 **Start Scripting**:

登入你的 Google 帳號:

按**新的空白專案**:

這會開啟新的專案, 請將編輯區內的預設程式刪除, 再按**未命名的專案**:

填入自訂的專案名稱:

1. 請開啟新的網頁連結至 https://github.com/FlagTech/FM611A_Extra/raw/master/lab06.js, 這是我們事先準備好的後端程式, 請選取完整程式後複製到剪貼簿:

回到 Apps Script 網頁, 將剛剛複製的程式貼到編輯器內, 並在第 1、2 行填入你自己的 AIO 使用者名稱與金鑰, 第 3 行填入前面建立 LINE 聊天機器人時產生的存取權杖:

按 <kbd>CTRL</kbd>+<kbd>S</kbd> 存檔。
1. 執行『**部署/新增部署作業**』指令將程式部署成網頁應用程式:

按**選取類型**後選**網頁應用程式**:

請依下圖選取各欄位後按**部署**:

按**授與存取權**:

選取你的 Google 帳戶:

按**進階**:

按**前往『語音開關』(不安全)**:

按**允許**:

完成部署, 會產生此網頁應用程式的網址, 可按左邊的**複製**鈕複製到剪貼簿:

複製網址後按**完成**。
:::info
如果修改 Google Apps Script 的程式, 就必須重新執行上述部署程序, 每次重新部署網址都會變化。
:::
## 修改 LINE 聊天機器人設定
1. 回到 LINE 聊天機器人網頁, 往下捲找到 **Webhook settings** 區間, 按 **Webhook URL** 項目右側的 **Edit**:

在 **Webhook URL** 欄位填入剛剛複製的網頁應用程式網址後按 **Update**:

按 **Verify** 確認網址正確:

按 **OK** 關閉:

打開 **Use webhook** 選項:

1. 往下捲找到 **LINE Official Account features** 區間, 按一下 **Auto-reply messages ** 項目右側的 **Edit**:

這會開啟新的網頁, 請在**進階設定**區間找到**自動回應訊息**項目, 設為**停用**:

1. 回到 LINE 開發人員頁面, 往上捲動即可找到此聊天機器人的 QR code:

請用手機 LINE App 掃描此 QR code 將此聊天機器人加入聯絡人:

即可按**聊天**與機器人對話:

若送出包含『打開』、『開燈』、『關閉』、『關燈』等關鍵字的訊息, 後端程式就會送出對應的數值到 AIO 上, 並回應『已傳送指令』:

在 AIO 上查看, 就會看到後端程式送來的資料:

## D1 mini 控制板程式
本例的 FlagsBlock 程式就和 〈[MQTT 版 Lab 06 語音聲控電源插座實作教學](/IsNCFSBqQMOlppZIx4r31g)〉一文的[程式](https://hackmd.io/IsNCFSBqQMOlppZIx4r31g#FlagsBlock-%E7%A8%8B%E5%BC%8F)一樣。