(本文作者是ALPHA Camp全端Web App開發課程的學生 Gary Wu,文章轉載自他的部落格)
Line是台灣滲透率最高的通訊軟體,月活躍用戶超過2000萬。很多商家也開發Line聊天機器人,做自動化客服和資訊查詢的功能。ALPHA Camp全端開發的學生 Gary Wu 透過在AC學會的後端開發能力,自己著手研究如何開發出簡單的Line chatbot。這篇文章有詳細實作步驟指南,帶你做出自己的第一個Line聊天機器人。
為什麼要做 chatbot?
上個月去聽 LINE chatbot 的講座,聽完後,想試試看 chatbot 到底可以做到什麼程度,雖然是機械式的聊天,但應該可以達到某種效果!也許可以幫助我解決我現在遇到的一些問題。
開始吧
因為是 LINE 提供的服務,所以需要先到 LINE Develpers 登入及註冊。
先到 https://developers.line.biz/en/ 登入
data:image/s3,"s3://crabby-images/c7a16/c7a16fe454249e398f392ddca7ef145e4ed983d6" alt=""
登入後,註冊,填寫 Name 、Email,並發送信箱認證信
data:image/s3,"s3://crabby-images/eda75/eda75d5b8715165cf642264dbb38457d9d812b20" alt=""
信箱認證完成 =>
data:image/s3,"s3://crabby-images/99ae4/99ae4bf158480bab8446b9fbb8b0231ce96ee5c8" alt=""
選擇要使用的服務: Messaging API
data:image/s3,"s3://crabby-images/5116f/5116f098288d74a31f18bcdae6cc765076573a8e" alt=""
Create new channel
Select provider:可以勾選已經存在的 provider,若沒有則新增一個 provider。
好了,就按 〈Next Page〉
輸入 provider name
data:image/s3,"s3://crabby-images/acb2a/acb2a65426bd325db2492e3c88a8ee8c1a2bd5fb" alt=""
完成相關資料輸入 => App icon、App name、Description、Category、 Subcategory、 Email address、 Privacy Policy URL、 Terms Of Use URL
data:image/s3,"s3://crabby-images/2a041/2a0416d59e1fc52338e73cc13e599fe77df07515" alt=""
Confirm:確認輸入資料正確性
data:image/s3,"s3://crabby-images/37345/37345f431821d993c12c47b39a5a0a36f05316aa" alt=""
channel 建立成功
data:image/s3,"s3://crabby-images/f329b/f329b546c8cac7de23bfd780225adcabeffbec6b" alt=""
更改 channel setting
data:image/s3,"s3://crabby-images/309e0/309e0b1f493047fdde0d3591506aaf9c96d34d95" alt=""
Channel ID 及 Channel Secret 很重要,不要外洩!
data:image/s3,"s3://crabby-images/feee8/feee8c736281e4e89a29a5e842962a2feba4be83" alt=""
這邊不用填 =>
data:image/s3,"s3://crabby-images/e1af6/e1af649bb6e2a940bf8d1da74c51728882b9ffe2" alt=""
最下面那個選項 Channel access token ,點選 Issue 可以產生 Channel access token
data:image/s3,"s3://crabby-images/03e49/03e49dd24b9d15c6fcb66ba3f4cd492d3df5f96a" alt=""
設定 Time until token 有效時間
data:image/s3,"s3://crabby-images/02f8e/02f8ed18fa50dbefb12444cb29c578c96b8bc4ec" alt=""
點選 Issue ,產生 token,這串 token 可用於 專案中。需要用到時再來查詢也可以。
data:image/s3,"s3://crabby-images/64c57/64c579304aba896ee5fb881259b94fb7df429052" alt=""
Messaging settings:
- Use webhooks 切換成 Enabled
- Webhook URL :先留空白,等建立 Webhook URL 後,再回頭設定
data:image/s3,"s3://crabby-images/757c1/757c18522e8e71e9075998f7be589757c150e1f3" alt=""
這邊不用設定,最下面有 chatbot 的 QR code ,用於加入好友。
data:image/s3,"s3://crabby-images/5ca3f/5ca3f13d6c7b6b2348e1850e3254ad01c743d2a5" alt=""
點選 Set message 會連到 LINE official Account Manager,有下面幾個畫面:
data:image/s3,"s3://crabby-images/cc8ca/cc8ca5f3f0aaa9e81aa35a9bc7b297c3300e9a32" alt=""
主頁 可以設定:群發訊息、貼文串、加入好友的觀迎訊息、自動訊息……
data:image/s3,"s3://crabby-images/37ab4/37ab4fb38af759491a61d7129d0f10429f1bafe7" alt=""
到此,已完成 Channel 的基本設定。接下來,要建立 Webhook URL
建立 Webhook URL
建立專案資料夾
mkdir XXXXXX
建立 package.json
npm init -y
安裝套件 express、linebot
npm install express linebot dotenv
linebot 套件說明: https://www.npmjs.com/package/linebot
安裝後,package.json dependencies 多了二個套件 express、 linebot、dotenv
data:image/s3,"s3://crabby-images/e8307/e8307687264becd0a7db812c85ca2b2f6e11a082" alt=""
建立 app.js
const express = require(‘express’)
const app = express()const linebot = require(‘linebot’);// 判別開發環境
if (process.env.NODE_ENV !== ‘production’) { // 如果不是 production 模式
require(‘dotenv’).config() // 使用 dotenv 讀取 .env 檔案
}const bot = linebot({
channelId: process.env.CHANNEL_ID,
channelSecret: process.env.CHANNEL_SECRET,
channelAccessToken: process.env.CHANNEL_ACCESS_TOKEN
});
const linebotParser = bot.parser();bot.on(‘message’, function (event) {
console.log(event);event.reply(event.message.text).then(function (data) {
// success
}).catch(function (error) {
// error
});
});app.post(‘/’, linebotParser);app.listen(process.env.PORT || 3000, () => {
console.log(‘Express server start’)
});
佈署到 heroku
在專案資料夾新增名稱為 Procfile 的檔案
web: node app.js
data:image/s3,"s3://crabby-images/5acd7/5acd7b00c0a9b01ab65302ba848898247b0d1351" alt=""
如果電腦有安裝 heroku CLI,則可以於專案資料夾路徑執行下面指令:
heroku login
會與連結到 heroku 網站,點選 log in
data:image/s3,"s3://crabby-images/60f91/60f91a09dbc346123744b4b20d5c90b7a2ba4603" alt=""
再回到 CLI,已登入 heroku
data:image/s3,"s3://crabby-images/41a4a/41a4ad62233f44204192e33da5ef46e6a424be9f" alt=""
建立一個 heroku app
heroku create
成功建立,左邊是 app 網址,右邊是 git push 位址
可用 git remote -v 指令來查詢
data:image/s3,"s3://crabby-images/3aa1f/3aa1f5a74139e04c0d93394f20aee50aef19f83f" alt=""
將專案 push heroku master
git push heroku master
push 後,會偵測哪一種語言撰寫的 app、建置 runtime environment、Installing binaries、Installing dependencies(相關套件)
data:image/s3,"s3://crabby-images/0b009/0b009ecaf88347798d640f6da05683dce017be02" alt=""
Discover process type(因為我們在專案中有建立 Procfile,讀取到 web)、Compressing、Lauching 、發行版次
data:image/s3,"s3://crabby-images/f9d6a/f9d6aef7f3f65ed03f23e7b1704b4be4503f8bdf" alt=""
查看 heroku logs
heroku logs –tail
data:image/s3,"s3://crabby-images/26bb7/26bb71bae810f82b91b6a1fefec99b391db828b8" alt=""
這裡出現二次同樣的錯誤訊息:使用 npm start 來啟動卻失敗
data:image/s3,"s3://crabby-images/c5e12/c5e12838cd668ac7df0dc82b972a5c91a8ea33bc" alt=""
原因是,我們在 package.json 沒有在 scripts 中定義 start。
所以我們來更改 package.json 設定:在 scripts 中增加二個屬性 dev 及 start。開發時可以 npm run dev 來啟動 server ,佈署時至 heroku 後,heroku 會以 npm run start 來啟動 server。
“scripts”: {
“dev”: “nodemon app.js”,
“start”: “node app.js”,
“test”: “echo “Error: no test specified”” && exit 1″”
}