質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
Google Apps Script

Google Apps ScriptはGoogleの製品と第三者のサービスでタスクを自動化するためのJavaScriptのクラウドのスクリプト言語です。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Q&A

解決済

1回答

2480閲覧

GASでHTTPリクエストをする際に「Content-Length: 0」をヘッダーに含める。

sanepy

総合スコア12

Google Apps Script

Google Apps ScriptはGoogleの製品と第三者のサービスでタスクを自動化するためのJavaScriptのクラウドのスクリプト言語です。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

0グッド

1クリップ

投稿2019/05/27 23:23

前提・実現したいこと

Google Apps ScriptでWebページの内容をスクレイピングしたいと考えています。

APIにHTTPリクエストを送信すると、取得するべき内容がレスポンスとして返ってくるので、これを取得しようとしています。
(GAS以外のソフトを使い、HTTPリクエストを投げれば答えが返ってくることは確認済みです。)

そのAPIが動作が独特で、HTTPリクエストのHeaderに必要事項がもれなく記載されていないと、エラー(500や418など)を返してきます。

その為、Headerに「Content-Length: 0」と入れたいのですが、GASでやろうとするとエラーになってしまいます。
(GAS以外のフリーソフトでは、Headerに「Content-Length: 0」といれると「200 OK」と、入れないと「500」を返してきます。)

GASで、エラーを無視して、Headerに「Content-Length: 0」を入れる方法はありませんでしょうか。

よろしくお願いいたします。

発生している問題・エラーメッセージ

指定された属性の値が無効です: Header:Content-Length(行 48、ファイル「コード」)

該当のソースコード

function sendPostRequestwordtogeo2(token,cookie){ Logger.log(token) Logger.log(cookie) var headers = { 'connection': 'keep-alive', 'x-csrf-token':token, 'cookie':cookie, 'Origin': 'https://www.example.com', 'x-requested-with': 'XMLHttpRequest', 'accept-language': 'ja-JP', 'Accept': '*/*', 'Referer': 'https://www.example.com/ja-JP/stores/', 'Content-Length':0, }; var payload = { }; var options = { 'headers': headers, 'method': 'POST', muteHttpExceptions: true, // 'payload':JSON.stringify() }; var fetch2 = UrlFetchApp.fetch('https://www.example.com/rtapi/locations/v2/autocomplete?query=XXXX',options); Logger.log(fetch2) }

試したこと

JavaScriptのエラー処理(https://wood-roots.com/web/jquery-javascript/57)や、muteHttpExceptionsの設定など試しましたが、やはり「エラー事態を無視してPOSTする」ことができません。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

kisojin

2019/05/28 00:01

UrlFetchAppでは`Content-Length`は内部で`payload`のサイズから自動で計算されます。今の場合、payloadがなければ`Content-Length`は自動で`0`になりますが、これではだめなのでしょうか。
tetsunosuke

2019/05/28 00:11

たしかに... https://stackoverflow.com/questions/26615546/google-apps-script-urlfetchapp-post-file こんなのがあって、optionsにわたすとドキュメントにはないけどうまく動くよ! って書いてあって試したんですけど、 無視されましたね・・・ https://requestbin.fullcontact.com/1p0p7921?inspect ここにリクエスト投げたあとがあるんですけど、結果的にContent-Lengthは0で受け取ってくれているみたいなのですが、そういう問題じゃないよな・・・と思ってます。
tetsunosuke

2019/05/28 01:12

https://issuetracker.google.com/issues/36755661 あ、こちらを読んでみたら、kisojinさんのコメントのとおりですね。 UrlFetchApp doesn't have an advanced parameter called 'contentLength'. The Content-Length header is automatically calculated based on the length of the payload passed in. The 'contentLength' advanced parameter you set in your sample is simply ignored by the backend and the length automatically calculated. payloadに例えば {"foo":"bar"} を渡したらContent-Length: 7 で送信されました。
papinianus

2019/05/28 08:26

そのスタックオーバーフローは"contentLength"というキーにしろと言っているように見えますが試しておられますか?
kisojin

2019/05/28 21:57

残念ながらoptionでの`contentLength`はありません。内部で無視されてしまいます。
guest

回答1

0

自己解決

解決していませんが、requestbinで確認(https://requestbin.fullcontact.com/rmqpuirm?inspect)したところ、Content-Lengthはkisojinさんの言う通り自動で0に設定されていました。

正常に作動した場合と、そうでない場合を比べると、GASから送信した場合、Headerの内容が改変されていることが判明しました。
(Content-Typeを設定しないでPOSTするとうまくいくが、GASからfetchで送信した場合、Content-Type: application/x-www-form-urlencodedと勝手に設定されており、これが原因かと思われます。)

原因がそもそも誤りであったため、クローズさせていただきます。

投稿2019/05/28 10:40

sanepy

総合スコア12

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問