Download the PHP package ycs77/laravel-line-bot without Composer
On this page you can find all versions of the php package ycs77/laravel-line-bot. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Informations about the package laravel-line-bot
Laravel Line Bot
開發中
在 Laravel 中快速開發 Line Bot
安裝前準備
- 建立一個 Laravel (或 Lumen) 專案
- 在 Line Developers 設定新的 Messaging API
- 準備一個 HTTPS 的網址,開發時建議使用 ngrok 來建立臨時網址。
安裝
使用 Composer 安裝:
發布設定檔案 (選用):
設定 Line Bot 金鑰到 .env
檔裡 (在剛才新增的 Messaging API 裡產生):
執行安裝指令,產生 Laravel LineBot 所需的檔案:
增加 webhook 路徑到 Laravel 的 VerifyCsrfToken
Middleware 中的 except
陣列,以禁用 CSRF 檢查:
app/Http/Middleware/VerifyCsrfToken.php
最後,開啟 Line Developers,關閉「歡迎訊息」和「自動回應訊息」,並開啟和設定 Webhook 網址:
Lumen
如果使用 Lumen,就需要別的方式來註冊。使用 Composer 安裝完套件後,首先先把 config 檔案複製到 config/linebot.php
(若 config 資料夾不存在請自行創建),然後開啟 bootstrap/app.php
,新增下方程式碼來註冊。
bootstrap/app.php
最後,執行 php artisan linebot:install
和在 Line Developers 設定 webhook 網址即可。
使用
首先先開啟 routes/linebot.php
,在 Laravel LineBot 中所有的監聽訊息及回傳訊息的程式,都是在這個檔案中:
routes/linebot.php
在這個範例中,如果用戶傳送 嗨
時,會自動回應 你好
。
監聽事件 (Event)
最基本的事件是監聽文字訊息事件,當然也可以使用 {name}
的替代文字來擷取用戶傳送的部分文字,並轉換成變數:
用法參考自 Botman
若沒有匹配成功任何訊息,將會回覆預設回應:
除了文字訊息事件,也可以監聽圖片訊息事件、跟隨事件等:
這些功能目前尚未完成
全部可以監聽的事件:
text()
: Text Message Event (文字訊息事件)image()
: (未完成) Image Message Event (圖片訊息事件)video()
: (未完成) Video Message Event (影片訊息事件)audio()
: (未完成) Audio Message Event (音檔訊息事件)file()
: (未完成) File Message Event (檔案訊息事件)location()
: (未完成) Location Message Event (位置訊息事件)sticker()
: (未完成) Sticker Message Event (貼圖訊息事件)follow()
: (未完成) Follow Event (加為好友事件)unfollow()
: (未完成) Unfollow Event (取消好友事件)join()
: (未完成) Join Event (LineBot 加入聊天室事件)leave()
: (未完成) Leave Event (LineBot 退出聊天室事件)memberJoin()
: (未完成) Member Join Event (其他人加入聊天室事件)memberLeave()
: (未完成) Member Leave Event (其他人退出聊天室事件)postback()
: (未完成) Postback Event (Postback 事件)accountLink()
: (未完成) Account Link Event (用戶連結事件)fallback()
: Fallback Event (預設回應)
回應 (Reply)
文字訊息:
按鈕選單:
行動按鈕使用方式請參考 行動按鈕 (Action)
全部可以使用的回覆訊息類型:
text()
: Text (文字)sticker()
: (未完成) Sticker (貼圖)image()
: (未完成) Image (圖片)video()
: (未完成) Video (影片)audio()
: (未完成) Audio (音檔)location()
: (未完成) Location (位置)imagemap()
: (未完成) Imagemap (圖片映射)template()
: Template (模板訊息)flex()
: (未完成) Flex
全部可以使用的模板訊息類型:
buttons()
: Template Buttons (按鈕選單)confirm()
: Template Confirm (確認)carousel()
: (未完成) Template Carousel (輪播)imageCarousel()
: (未完成) Template Image carousel (圖片輪播)
快速回覆 (Quick Reply)
行動按鈕使用方式請參考 行動按鈕 (Action)
快速回覆無法使用 Url Action
行動按鈕 (Action)
行動按鈕需搭配 Quick Reply 和 Template 訊息使用。以下為使用範例:
全部可以使用的行動按鈕:
message()
: Message (文字訊息)url()
: Url (網址)postback()
: Postbacklocation()
: Location (選擇位置)datetimePicker()
: Datetime Picker (日期)camera()
: Camera (相機)cameraRoll()
: Camera Roll (圖片庫)
用戶資訊
取得 Line 用戶資料
使用 LineBot::profile()
即可取得當前用戶的資訊:
可以取得的用戶資訊:
id()
: User IDname()
: 用戶顯示名稱 (暱稱)picture()
: 用戶大頭貼網址status()
: 用戶狀態消息文字
整合 Eloquent
這個功能預設是關閉的,需要先把 LineBot 設置中的 user.enabled
改成 true
,才可以開始使用 Eloquent:
還可以依需求調整
model
(用戶模型) 及id
(辨識用戶的欄位名稱)。
config/linebot.php
在 Lumen 中需要開啟
bootstrap/app.php
取消$app->withEloquent();
的註釋
然後將 users
資料表修改成以下欄位,和運行 php artisan migrate
:
database/migrations/2014_10_12_000000_create_users_table.php
修改 User Model:
app/User.php
最後,就可以使用 LineBot::user()
來取得用戶模型了:
Rich Menu
新增 Rich Menu 和上傳圖片
詳細配置請參考 Line 官方說明:Using rich menus
準備一張 Rich Menu 的圖片
在 config/linebot.php
中設定 rich_menu
的設定 (建議可以使用 LINE Bot Designer 來產生)。每個 Rich Menu 都要設定對應的 key (跟 Line 官方沒有關係,只是用來辨識 Rich Menu 而已),例如範例將 key 設定為 rich_menu_1
:
routes/linebot.php
執行 linebot:richmenu:create
命令新增 Rich Menu 和上傳圖片,參數需要 Rich Menu 的 key (上方 config 設定) 和圖片路徑 (範例圖片路徑為 "public/image.jpg"
):
查看 Rich Menu
查看全部 Rich Menu ID:
查看全部 Rich Menu 的原始資料:
刪除 Rich Menu
刪除指定 Rich Menu ID:
刪除全部 Rich Menu:
調用 LINE 官方 SDK 的 API
使用 LineBot::base()
即可調用 LINE 官方 SDK 的 API:
參考
測試
運行測試:
運行指令產生測試覆蓋率報告,報告產生在 build/coverage-report
:
License
Under the MIT license.
All versions of laravel-line-bot with dependencies
facade/ignition-contracts Version ^1.0
illuminate/console Version ~5.7|~5.8|^6.0
illuminate/contracts Version ~5.7|~5.8|^6.0
illuminate/database Version ~5.7|~5.8|^6.0
illuminate/http Version ~5.7|~5.8|^6.0
illuminate/support Version ~5.7|~5.8|^6.0
linecorp/line-bot-sdk Version ^4.1