この記事では、Google Apps Script (GAS) を利用して、LINE BOTで「ポストバックアクション」を使用する方法を解説します。
ポストバックアクションは、ユーザーがボタンをタップした際に、テキストメッセージを送信するのではなく、サーバー側(GAS)に特定のデータ(ポストバックデータ)を送信する機能です。これにより、ユーザーには見えないデータをトリガーとして、BOT側で様々な処理を分岐させることが可能になります。
公式ドキュメントはこちらを参照してください。


事前準備
実装を始める前に、以下の準備が必要です。
- チャンネルアクセストークンの取得: LINE Developersコンソールからアクセストークンを取得します。
LINE BOT開発に不可欠なMessaging APIのチャンネルアクセストークンを取得する手順を、実際の画面キャリプチャを交えて詳しく解説します。LINE Developersへの登録からプロバイダー、チャンネル作成、トークン発行までを網羅。
- ユーザーIDの取得: メッセージの送信先となるご自身のLINEユーザーIDを取得します。
Google Apps Script(GAS)を使って、LINE BOTと友だちになっているユーザーのIDを取得する方法を解説します。Webhook経由で送信されるイベント情報から、特定のユーザーを識別するための`userId`を抜き出すサンプルコードを紹介します。
- スクリプトプロパティの設定: 今回のサンプルコードでは、アクセストークンとユーザーIDをスクリプトプロパティに保存して使用します。以下の記事を参考に、
TOKENとDEBUGIDというキーでそれぞれの値を設定してください。
Google Apps Script(GAS)を使って、特定のキーワードに反応するシンプルなLINE BOTを作成する手順を解説します。Googleアカウントさえあれば無料で開発可能。初心者でもコピペで実装できるよう、コードと設定方法を詳しく紹介します。
実装コード
以下の関数は、ポストバックアクションが設定されたボタンテンプレートメッセージを送信します。
/*
ボタンテンプレートメッセージを送る(postback)
-----------------------------*/
function postback_action() {
/* スクリプトプロパティのオブジェクトを取得 */
const prop = PropertiesService.getScriptProperties().getProperties();
/* ボタンテンプレートメッセージを送る(postback) */
UrlFetchApp.fetch('https://api.line.me/v2/bot/message/push', {
'headers': {
'Content-Type': 'application/json',
'Authorization': 'Bearer ' + prop.TOKEN, // スクリプトプロパティにトークンは事前に追加しておく
},
'method': 'POST',
'payload': JSON.stringify({
"to": prop.DEBUGID, // スクリプトプロパティに送信先IDは事前に追加しておく
"messages": [
{
"type": "template",
"altText": "postback",
"template": {
"type": "buttons",
"thumbnailImageUrl": "https://placehold.jp/640x480.jpg?text=postback", // 画像のURL
"imageAspectRatio": "rectangle",
"imageSize": "cover",
"imageBackgroundColor": "#FFFFFF",
"title": "メニュー",
"text": "以下より選択してください。",
"actions": [
{
"type": "postback",
"label": "ポストバック1",
"data": "action=postback1&item=A" // Webhookで受け取るデータ
},
{
"type": "postback",
"label": "ポストバック2",
"data": "action=postback2&item=B" // Webhookで受け取るデータ
}
]
}
}
],
"notificationDisabled": false // trueだとユーザーに通知されない
}),
});
}
actions配列内の各オブジェクトでtypeにpostbackを指定し、labelにボタンの表示名、dataにサーバーに送信したいデータを文字列で設定します。
動作確認
GASのスクリプトエディタでpostback_action関数を実行すると、LINEにボタン付きのメッセージが届きます。

ボタンをタップすると、そのアクションに設定されたdataがWebhook URL(GASのウェブアプリURL)に送信されます。GAS側でdoPost(e)関数を実装することで、このデータを受け取り、内容に応じた処理を実行できます。
以下は、スプレッドシートにポストバックデータを記録する簡単なログ出力の例です。
- 「ポストバック1」をタップすると、
data: action=postback1&item=Aというデータが送信されます。 - 「ポストバック2」をタップすると、
data: action=postback2&item=Bというデータが送信されます。
ポストバックイベントの受け取り方については、以下の記事も参考にしてください。
Google Apps Script(GAS)を使って、特定のキーワードに反応するシンプルなLINE BOTを作成する手順を解説します。Googleアカウントさえあれば無料で開発可能。初心者でもコピペで実装できるよう、コードと設定方法を詳しく紹介します。
その他のアクションオブジェクトについては、以下の記事でまとめて解説しています。
LINE BOT開発で必須のアクションオブジェクト7種類(ポストバック、メッセージ、URI、日時選択、カメラ、カメラロール、位置情報)の機能と使い方をGoogle Apps Script (GAS) のサンプルを交えて徹底解説。それぞれの違いや最適な使い分けがわかります。
まとめ
今回は、GASを使ってLINE BOTでポストバックアクションを利用する方法を紹介しました。ユーザーの選択に応じて複雑な処理をサーバー側で実行したい場合に不可欠な機能です。

