[解決済み] HTTP GET(リクエストボディ付き
質問
アプリケーションのために新しいRESTfulなウェブサービスを開発しています。
あるエンティティに対してGETを行うと、クライアントはそのエンティティの内容を要求することができます。 もし、何らかのパラメータを追加したい場合(例えば、リストのソートなど)には、クエリ文字列でこれらのパラメータを追加することができます。
あるいは、リクエスト・ボディでこれらのパラメータを指定できるようにしたい。 HTTP/1.1 は、これを明確に禁止していないようです。これにより、より多くの情報を指定できるようになり、複雑な XML リクエストの指定がより簡単になるかもしれません。
私の質問です。
- これは良いアイデアなのでしょうか?
- HTTPクライアントは、GETリクエスト内でリクエストボディを使用する際に問題が発生しますか?
https://www.rfc-editor.org/rfc/rfc2616
解決方法は?
GETリクエストにボディを含めることに関するRoy Fieldingのコメント .
つまり、どのようなHTTPリクエストメッセージもメッセージボディを含むことが許されており、それを考慮してメッセージを解析しなければなりません。しかし、GET のサーバーセマンティクスは、もしボディがあったとしても、そのリクエストに対して何の意味も持たないように制限されています。構文解析に関する要件は、メソッドのセマンティクスに関する要件とは別である。
つまり、GETでボディを送信することは可能ですが、そうすることは決して有益ではありません。
これはHTTP/1.1のレイヤーデザインの一部で、仕様が分割されれば再び明らかになります(作業中)。
...ロイ
はい、GETでリクエストボディを送ることはできますが、それには何の意味もないはずです。もし、サーバー上で解析して意味を持たせ、かつ その内容に基づいてレスポンスを変更する での推奨を無視することになります。 HTTP/1.1 仕様書のセクション 4.3 では :
...リクエストメソッドがエンティティボディのための定義されたセマンティクスを含んでいない場合、メッセージボディは べきである は、リクエストを処理するときに無視される。
でのGETメソッドの記述も HTTP/1.1 仕様書の 9.3 節にある :
GETメソッドは、Request-URIで特定される情報([...])を取得することを意味します。
で、GETリクエストではリクエストボディはリソースの識別に含まれず、リクエストURIのみであることを述べています。
更新情報
HTTP/1.1 spec"として参照されたRFC2616は、現在では廃止されています。2014年にはRFC 7230-7237に置き換わっています。引用"the message-body SHOULD be ignored when handling the request"は削除されました。現在は、"Request message framing is independent of method semantics, even if the method doesn't define any use for a message body" 2nd quote "The GET method means retrieve whatever information ... is identified by the Request-URI" が削除されただけです。 - コメントより
から HTTP 1.1 2014年版仕様 :
GETリクエストメッセージ内のペイロードは、定義されたセマンティクスを持たない。GETリクエストでペイロードボディを送信すると、既存の実装によってはリクエストを拒否する原因になるかもしれない。
関連
-
[解決済み】Android 8:クリアテキストのHTTPトラフィックが許可されない
-
[解決済み] cURLでJSONデータをPOSTするにはどうすればよいですか?
-
[解決済み] java.net.URLConnectionを使用してHTTPリクエストを発生させ処理する方法
-
[解決済み] HTTP POSTリクエストでは、どのようにパラメータが送信されるのですか?
-
[解決済み] updateとdeleteのHTTPステータスコード?
-
[解決済み] カスタムHTTPヘッダー:命名規則
-
[解決済み] リソースが既に存在する場合の POST に対する HTTP レスポンスコード
-
[解決済み] JavaScriptでHTTP GETリクエスト?
-
[解決済み] HTTP DELETE リクエストにエンティティボディは許されますか?
-
[解決済み】HTTPのPOSTとPUTの違いは何ですか?
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み] HTTP GET(リクエストボディ付き
-
[解決済み] API のバージョン管理に関するベストプラクティス?[クローズド]
-
[解決済み] RESTリソースの命名規則はSingularとPluralのどちらを使用すべきですか?
-
[解決済み] RESTアプリケーションはステートレスであることが前提である場合、セッションはどのように管理するのですか?
-
[解決済み] URLクエリパラメータを含むHTTP POST -- 良いアイデアかどうか?
-
[解決済み] RESTのネストされたリソースのベストプラクティスは何ですか?
-
[解決済み] REST Web アプリケーションのページネーション
-
[解決済み] RESTでトランザクション?
-
[解決済み] HATEOAS(REST-architecture)の実例集 [終了しました]。
-
[解決済み] NetflixやTwitterのようなWebサービスにはRESTとSOAPのどちらを使うべきか?[クローズド]