Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
解説!LINE bot開発
Search
ufoo68
May 17, 2021
Technology
330
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
解説!LINE bot開発
ufoo68
May 17, 2021
More Decks by ufoo68
See All by ufoo68
BlenderをCodexで動かす
ufoo68
0
260
改めて考えるOSSのあり方について
ufoo68
0
55
文法で学ばないJavaScript
ufoo68
0
70
Cookieとは?
ufoo68
1
81
今更ながら、開発現場での生成AI活用について
ufoo68
0
82
28歳独身エンジニア 婚活してみた
ufoo68
0
34
OpenAIでクッキー型を作る
ufoo68
1
67
初めて開発リーダーをやってみた話
ufoo68
0
140
M5Stack用の指紋認証デバイスを試す
ufoo68
0
900
Other Decks in Technology
See All in Technology
個人の発見を、組織の知恵に 〜生成AI活用を"探索"から"組織の仕組み"へ〜
kintotechdev
2
980
タクシーアプリ『GO』の実践的データ活用
mot_techtalk
2
150
2026.06.13_AI時代に事業会社が「SIer出身エンジニア」を求める理由 / Why Businesses Seek Engineers with a System Integrator Background in the AI Era
jumtech
0
500
イベントストーミングとKiroの仕様駆動開発で実現する要件の認識合わせプロセス
syobochim
7
1.2k
OCI Oracle AI Database Services新機能アップデート(2026/03-2026/05)
oracle4engineer
PRO
0
220
実装は速くなった、レビューはどうする? ― 自身のレビューをAIで再現させるサーヴァントエンジニアリングのすゝめ / Implementation got faster. So what about reviews? — An invitation to Servant Engineering: Recreating your own code reviews with AI
nrslib
6
3.8k
新規ゲーム開発におけるAI駆動開発のリアル
202409e2
0
2.5k
AI Adaptable なテストを整える工夫 / Ways to Make Your Tests AI-Adaptable
bitkey
PRO
3
210
AIにフローを作らせようとして挫折した話
hamatsutaichi
0
190
10倍の生産性を実現するAI駆動並列エージェントのすべて
kumaiu
2
220
EventBridge Connection
_kensh
4
520
トークン数だけでは測れない — Claude Code 組織展開の効果検証から学んだこと
makikub
0
130
Featured
See All Featured
Claude Code どこまでも/ Claude Code Everywhere
nwiizo
65
56k
KATA
mclloyd
PRO
35
15k
Self-Hosted WebAssembly Runtime for Runtime-Neutral Checkpoint/Restore in Edge–Cloud Continuum
chikuwait
0
570
Site-Speed That Sticks
csswizardry
13
1.2k
RailsConf & Balkan Ruby 2019: The Past, Present, and Future of Rails at GitHub
eileencodes
141
35k
Max Prin - Stacking Signals: How International SEO Comes Together (And Falls Apart)
techseoconnect
PRO
0
170
Making the Leap to Tech Lead
cromwellryan
135
9.9k
Code Reviewing Like a Champion
maltzj
528
40k
Building a A Zero-Code AI SEO Workflow
portentint
PRO
0
550
Scaling GitHub
holman
464
140k
Digital Projects Gone Horribly Wrong (And the UX Pros Who Still Save the Day) - Dean Schuster
uxyall
0
1.6k
Prompt Engineering for Job Search
mfonobong
0
330
Transcript
解説!LINE bot開発 @linedc
自己紹介 • Twitter ◦ @ufoo_yuta • Qiita ◦ ufoo68 •
所属 ◦ 株式会社ACCESS • やってること ◦ スポーツIoTLT主催 ◦ LINE API Expert
私とQiita 私のLINE APIで遊んだ記録はだいたいQiitaで書いてました 初めて書いた記事 「LINE Thingsでパトランプを回してみた」
今日の内容 昔書いた記事について、もう少しLINE botについて解説します! 知識が浅かった頃に書いたものなので、色々と雑な ことを書いているところが多々ありました。 でもなぜか一番LGTMもらっているのはこの記事な んですよねぇ
LINE botってどうやってつくるの? Messaging APIで作れる! https://developers.line.biz/ja/docs/messaging-api/overview/
Messaging APIをどうやって使うの? 今年のアニメを教えてくれるLINE botを例に見ていきましょう! 「今年のアニメは?」というメッセージを LINE トーク 画面に送ると、今年放送予定のアニメを教えてくれ る。そんなbotです。
まずはDevelopersサイトに登録しよう ログインをしたらこんな感じのコンソール画面がでてきます!
プロバイダを作成してチャネルを作る プロバイダはアプリをつくるためのフォルダ、チャネルはアプリそのもの とイメージするとわかりやすいと思います
必要情報を記入します ここはLINE botのアイコンとか説明文とかを書きます
実はLINE botはこれで完成です しかし今の状態ではメッセージを受け取ることはできても、返すことはできない ・・・・・・・・。 「今年のアニメは?」っと ...
まずはLINE Official Account Managerを開く 応答について設定する Messaging APIを使いたい場合は Botモードを選択 応答メッセージをONにすると設定画面から定型 文を返すBotが設定できる(しかし
Messaging APIを使う場合はOFFにする)
改めてMessaging APIについて アプリケーションとLINE botとコミュニケーションを繋ぐための仕組み https://developers.line.biz/ja/docs/messaging-api/overview/ 今年のアニメは? 「今年のアニメは?」 と質問されたよ 今年のアニメ一覧を 返します
今年のアニメ一覧が 返ってきたよ
Messaging APIを使うための必要情報 • 以下の情報を設定画面 (LINE Developers & LINE Official Account)から確認・設定する
◦ Webhook URL ◦ Chanel access token ◦ Chanel secret Messaging API Application https://xxxxx.xxxx Webhook URLはMessaging APIがLINE からのメッセージを送る先を示す Chanel access token = xxxxx Chanel secret = xxxxxx Chanel access tokenとChanel secretは、 アプリケーションがMessaging APIに送る メッセージが信用できることを示す
アプリケーションの実装について 実装にはどんなサービスを使っても良いと思いますが、 サーバーレスなものを使う方が無難だと思います。 Endpoint Function Messaging API サーバーレスであればこの Function の実装に専念するだけで
LINE botが 実装できる(基本的にこの構成が変 わることはない) https://xxxxx.xxxx
コードの実装・・・の前に メッセージの送信方法は2通りある Messaging API Application Messaging API Application Messaging APIから送られたメッセージを受
け取ってから返すパターン Messaging APIに直接メッセージを送るパ ターン(送信数に制限あり) reply message push message
各メッセージ送信のパターン JavaScriptの例(公式提供のライブラリを使用) • リプライメッセージ replyMessage(token, message) ←tokenはMessaging APIから送られてきた情報から取得 • プッシュメッセージ
pushMessage(to, message) ←toでMessaging APIが送信して欲しいLINE botを指定 ちなみに、APIのリファレンスは公開されているので、アプリケーションの実装では好きな 言語を選択することもできる
メッセージにも色々な種類がある • テキスト • 画像 • 動画 • 音声 •
ファイル • 位置情報 • スタンプ
テキスト→テキストを返すbotの実装例 const line = require('@line/bot-sdk') const config = { channelSecret:
’xxxxxxx’, channelAccessToken: ’xxxxxxx’ } const client = new line.Client(config) …. async function handleEvent(event) { …. if (event.type.message.text === ‘今年のアニメは?’) { const animeList = await getCurrentAnimeList() return client.replyMessage(event.replyToken, animeList) } …. } 基本的に前処理で書くことはどの LINE botを実 装する場合も同じ(そこらへんのサンプルコード をコピペしても良い) 受け取ったメッセージとその内容を元に返信する メッセージを記述(自分で実装を考えるのはここ だけ)
実装ができたら Webhook URLを登録しよう
友達登録をして動作確認をしよう QRコードを読み込むと勝手にLINEアプリが立ち上がるはず
おわりに • LINE botを作るための仕組みとしてMessaging APIというものがある • Messaging APIとはLINEアプリと自作サーバーアプリケーションの間のメッセージ 交換を繋ぐ役割を持っている •
LINEのメッセージには複数の種類がある(今回はテキストの例を紹介) • アプリケーションの動作確認は作成したLINE botを友達登録するだけで実行可能 • 具体的な実装は超絶簡単!LINE bot開発を参照してね