前言
以前從花落落的文件中找到一個方法,像是使用 push message
我都會笨笨的 call API 的方法去執行功能,殊不知 SDK 早就包好了,然後邊做邊罵自己為什麼要解這些 JSON (拍桌)
到了現在比較會看文件,才知道原來以前是自己雷自己 (捶心肝)…接下來就試玩幾個我覺得常會用到的 method 好了不廢話了,來簡單介紹一下一些常用的方法 😎
get_profile
回傳使用者的個人狀態,可以透過每次的 reply 去拿到使用者的資訊,一般使用的話都話把它存下來,等之後有介接其他服務時方便使用 userId 去判斷使用者。
1 | profile = line_bot_api.get_profile(event['events'][0]['source']['userId']) |
這邊搭配 ImageSendMessage
來幫忙發送圖片,他主要是透過 original_content_url 以及 preview_image_url 這兩個參數來幫忙轉成圖片
- original 就是讓使用者看到的圖片
- preview 在還沒載入時的樣子
push_message
既然都取到使用者的 id 了,下一步就是推訊息給使用者啦!
建立一個 GET 的路由在 /webhook 上,收到 query string 的 msg 的值並找到所有使用者的 id 並逐一推送訊息。
1 | line_bot_api = LineBotApi(os.getenv('LINE_CHANNEL_TOKEN')) |
Reply Mode
LocationSendMessage
這邊直接拿 SDK 的範例來用,若是有在做商家功能的機器人可以使用這個方式讓使用者接收到商家訊息~
1 | self.line_bot_api.reply_message(token, LocationSendMessage( |
StickerSendMessage
這個方法可以搭配使用,讓整個回應看起來跟真實吧!
不知道清單能用什麼可以參考,
1 | self.line_bot_api.reply_message(token, StickerSendMessage(package_id='1',sticker_id='1')) |
Button Template
1 | buttons_template_message = TemplateSendMessage( |
結論
簡單玩了幾個 API,大概就這幾個比較常搭配著使用,用過之後才知道其實有好多 API 我都還不是很清楚用法 🤣
而 LINE 最近更新了他們文件的功能,多了一個Try
的按鈕提供使用者可以線上直接測 API,只是像是 push messages 這個就剛好沒有 😓,但至少有很多 API 不用通靈去測試,直接拿著 Token 在網頁上測試嚕!
Doc Sample
Code is here