前提・実現したいこと
LINE botでdoPost関数を実行しようとしています。
メッセージを送ると「hi」と返してくるbotを作ろうとしています。
発生している問題・エラーメッセージ
メッセージを送っても既読のみついて返事がなく、次のエラーメッセージが表示されます。
原因としてどんなことが考えられるでしょうか。
https://api.line.me のリクエストに失敗しました(エラー: 400)。サーバー応答の一部: {"message":"The property, 'messages', in the request body is invalid (line: 1, column: 61)"}(応答の全文を見るには muteHttpExceptions オプションを使用してください) at reply(コード:38) at doPost(コード:15) すべて展開 | すべて折りたたむ{ insertId: "ezrbpef1cd8ad" jsonPayload: { context: {…} message: "https://api.line.me のリクエストに失敗しました(エラー: 400)。サーバー応答の一部: {"message":"The property, 'messages', in the request body is invalid (line: 1, column: 61)"}(応答の全文を見るには muteHttpExceptions オプションを使用してください) at reply(コード:38) at doPost(コード:15) " serviceContext: {…} } labels: {…} logName: "projects/kisaragi/logs/script.googleapis.com%2Fconsole_logs" receiveTimestamp: "2019-12-05T15:09:39.812401346Z" resource: {…} severity: "ERROR" timestamp: "2019-12-05T15:09:38.902Z" }
該当ソースコード
2行目のUrlFetchApp.fetch(url, {
でエラーが出ております。
javascript
1var url = 'https://api.line.me/v2/bot/message/reply'; 2UrlFetchApp.fetch(url, { 3'headers': { 4'Content-Type': 'application/json; charset=UTF-8', 5'Authorization': 'Bearer ' + channelToken, 6}, 7'method': 'post', 8'payload': JSON.stringify({ 9'replyToken': replyToken, 10'messages': message, 11}), 12});
ソースコード全文
javascript
1function doPost(e) { 2 var replyToken = JSON.parse(e.postData.contents).events[0].replyToken; 3 var user_id = JSON.parse(e.postData.contents).events[0].source.userId; 4 var input = JSON.parse(e.postData.contents).events[0].message; 5 if (typeof replyToken === 'undefined') {return;} 6 var userMessage = input.text; 7 8 var channelToken = 'チャンネルトークン'; 9 10// var message = Calendar.getPlan(); 11 var message = "hi"; 12 13 14 Func.reply(replyToken, message, channelToken); 15 console.log(message); 16 return ContentService.createTextOutput(JSON.stringify({'content': 'post ok'})).setMimeType(ContentService.MimeType.JSON); 17} 18 19//メッセージ送信 20function reply(replyToken, message, channelToken) { 21 var url = 'https://api.line.me/v2/bot/message/reply'; 22 UrlFetchApp.fetch(url, { 23 'headers': { 24 'Content-Type': 'application/json; charset=UTF-8', 25 'Authorization': 'Bearer ' + channelToken, 26 }, 27 'method': 'post', 28 'payload': JSON.stringify({ 29 'replyToken': replyToken, 30 'messages': message, 31 }), 32 }); 33}
試したこと
JavaSscript内のチャンネルトークン、LINE Developersに貼り付けるWebhook URLに間違いがないか何度も確認しました。webhook URIを張り付けた後「検証」を押すと「成功」と出ました。
回答1件
あなたの回答
tips
プレビュー