LINEの友達のユーザーIDは通常のアカウントから確認することはできません。
ユーザーIDを確認するには、LINEのボットを作成し、何かメッセージが送られたら、その人のユーザーIDを返すことで確認する方法があります。
設定の流れ
LINEで友だちの登録情報をスプレッドシートに自動で記録するには(LINE Messaging APIを利用する必要があります。
大まかな流れは以下のようになります。
- Messaging APIのチャネルを作成(LINE Official Account Manager)
- チャネルアクセストークンの発行(LINE Developers)
- GASでプログラムを作成
- Webhook URLを生成して登録する
- メッセージを送信する
Messaging APIのチャネル作成(LINE Official Account Manager)
まずは、Messaging APIのチャネルを作成します。
通常の公式LINE(LINE Official Account Manager)にログインし、対象となるアカウントを選択します。
右上にある「設定」をクリックします。
data:image/s3,"s3://crabby-images/60272/602726c43a8866cc48ec2b53f95da1cea73c19b9" alt=""
「設定 > Messaging API」をクリックします。
data:image/s3,"s3://crabby-images/19068/19068668729941ac96b0a827aedfa72040823033" alt=""
「Messaging APIを利用する」をクリックします。
data:image/s3,"s3://crabby-images/bbfbb/bbfbb4091530634cc9413a41223b6b93e0319669" alt=""
プロバイダーを新規作成、または既存の中から選択します。
プロバイダーとは、LINEの様々なサービス(LINE公式アカウント、LINEログイン、LINEミニアプリなど)を提供する組織(企業)のことです。
1つのプロバイダーに対して、複数のチャネルを設定することができます。
data:image/s3,"s3://crabby-images/04ec3/04ec37da097ff7343d4eef1f70e28c0fe96c0eed" alt=""
- 一度プロバイダーを連携すると、変更・解除をすることができません。
- プロバイダー名はLINEで友だち登録するときなどに表示されるため、しっかりと検討することをおすすめします。
- プロバイダー名は後から変更できます。
プライバシーポリシーや利用規約のURLがある場合はリンクを入力します(省略可能)。ない場合は「OK」をクリックします。
data:image/s3,"s3://crabby-images/85baf/85baf0b4ba5aeb95c10af3f0deb44daab63c5628" alt=""
「OK」をクリックします。
data:image/s3,"s3://crabby-images/a900f/a900f6161c3a089ce83cd50f6ec9af4c67043d50" alt=""
連携が完了すると、「Channel ID」や「Channel secret」が設定されます。
data:image/s3,"s3://crabby-images/d8f8b/d8f8bcf04fbf244b7b6378026dd46b798803db8d" alt=""
チャネルアクセストークンの発行(LINE Developers)
GASでプログラムを組む前に、Messaging APIのチャネルアクセストークンを発行する必要があります。
チャネルアクセストークンはLINE Developersというツールから作成する必要があります。検索するか、下記URLからログインできます。
ログイン情報は通常のLINEと同じです。
プロバイダーの一覧が表示されるので、対象のプロバイダーを選択します。
Messaging APIのチャネルが追加されているので、これをクリックします。
data:image/s3,"s3://crabby-images/ec5b6/ec5b66e1e3e4909cc10d87b3c9239a5acc8b027e" alt=""
タブを「Messaging API設定」にします。
data:image/s3,"s3://crabby-images/55a51/55a518b1c6c61b9b66efd9615e1896278563bf05" alt=""
一番下に「チャネルアクセストークン」があるので「発行」をクリックします。
data:image/s3,"s3://crabby-images/50e7a/50e7a9782a9b6db3009a571819d7520c808b5a20" alt=""
トークンが発行されるので、コピーします。
data:image/s3,"s3://crabby-images/ef4ee/ef4ee12ca7550bd1f7c11844d8d0254e427dc287" alt=""
また、「Webhookの利用」をONにしておきます。
data:image/s3,"s3://crabby-images/02571/0257113cc8810e7d5576d6709389bb0150ae2783" alt=""
GASでプログラムを作成
続いてGASでプログラムを作成します。
「CHANNEL_ACCESS_TOKEN」の部分に、上記で発行したチャネルアクセストークンをセットします。
const CHANNEL_ACCESS_TOKEN = 'LINEのチャネルアクセストークン';
function doPost(e) {
const eventData = JSON.parse(e.postData.contents);
// イベントデータが存在するか確認
if (eventData.events && eventData.events.length > 0) {
const event = eventData.events[0];
// ユーザーIDとリプライトークンが取得できる場合のみ処理を実行
if (event.type === 'message' && event.message.type === 'text' && event.replyToken) {
const userId = event.source.userId;
const replyToken = event.replyToken;
replyUserId(replyToken, userId);
} else {
console.log("イベントタイプまたはリプライトークンが見つかりません");
}
} else {
console.log("イベントデータが存在しません");
}
}
// ユーザーIDを返信する関数
function replyUserId(replyToken, userId) {
const url = 'https://api.line.me/v2/bot/message/reply';
const messages = [
{
type: 'text',
text: `あなたのユーザーIDは: ${userId} です`
}
];
const options = {
method: 'post',
headers: {
'Content-Type': 'application/json',
'Authorization': `Bearer ${CHANNEL_ACCESS_TOKEN}`
},
payload: JSON.stringify({
replyToken: replyToken,
messages: messages
})
};
const response = UrlFetchApp.fetch(url, options);
console.log(response.getContentText());
}
右上の「デプロイ」をクリックし「新しいデプロイ」を選択します。
data:image/s3,"s3://crabby-images/8e397/8e397bfd8dd2a9e58171d3eb7381752a4fcb282d" alt=""
data:image/s3,"s3://crabby-images/9d17e/9d17ebaa5e0838713dc4032d49bfb87cdef12f6c" alt=""
「種類の選択」の歯車アイコンをクリックして「ウェブアプリ」を選択します。
data:image/s3,"s3://crabby-images/84414/84414b87d05e39b92b8f52364d1d9f68a3c373e1" alt=""
アクセスできるユーザーを「全員」とし、「デプロイ」をクリックします。
data:image/s3,"s3://crabby-images/532d0/532d02fb56dcf56a51183ed6136cc44f4fbbc660" alt=""
ウェブアプリのURLをコピーします。
data:image/s3,"s3://crabby-images/86565/8656513402a7c62cc83938e674d20ce07f9ff491" alt=""
コピーしたURLを、LINEのMessaging APIのWebhook URLに貼り付けて「保存」をクリックします。
data:image/s3,"s3://crabby-images/d0717/d071758065cf51fae4bbcdeba114016c73cd92ac" alt=""
以上でLINEボットの作成は完了です。
メッセージを送信する
LINEから対象のアカウントに対してメッセージを送信します。
するとユーザーIDを自動で返します。
data:image/s3,"s3://crabby-images/58290/58290a5c3b1bbe7234edab5463d733a6b9ec0e64" alt=""
これでユーザーIDの取得が完了です。