apiを叩くさいのpostとgetにつきまして
- 評価
- クリップ 2
- VIEW 10K+

退会済みユーザー
仕組みがよくわからないので、教えていただけると幸いです。
よく「apiを叩く」と言いますが、
データをサーバーに保存する際にもajaxなどで、
urlを'/menu/list'などとして、jsonデータをpostすると思うのですが、
この時は、サーバーサイドでは/menu/listをgetしているのでしょうか?
また、データを取得する際にgetを使う際は、
サーバーサイドではpostして、フロントサイドでgetするということなのでしょうか?
-
気になる質問をクリップする
クリップした質問は、後からいつでもマイページで確認できます。
またクリップした質問に回答があった際、通知やメールを受け取ることができます。
クリップを取り消します
-
良い質問の評価を上げる
以下のような質問は評価を上げましょう
- 質問内容が明確
- 自分も答えを知りたい
- 質問者以外のユーザにも役立つ
評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。
質問の評価を上げたことを取り消します
-
評価を下げられる数の上限に達しました
評価を下げることができません
- 1日5回まで評価を下げられます
- 1日に1ユーザに対して2回まで評価を下げられます
質問の評価を下げる
teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。
- プログラミングに関係のない質問
- やってほしいことだけを記載した丸投げの質問
- 問題・課題が含まれていない質問
- 意図的に内容が抹消された質問
- 過去に投稿した質問と同じ内容の質問
- 広告と受け取られるような投稿
評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。
質問の評価を下げたことを取り消します
この機能は開放されていません
評価を下げる条件を満たしてません
質問の評価を下げる機能の利用条件
この機能を利用するためには、以下の事項を行う必要があります。
- 質問回答など一定の行動
-
メールアドレスの認証
メールアドレスの認証
-
質問評価に関するヘルプページの閲覧
質問評価に関するヘルプページの閲覧
+5
かなり誤って覚えているようです。
RFCで定義を確認してください。
投稿
-
回答の評価を上げる
以下のような回答は評価を上げましょう
- 正しい回答
- わかりやすい回答
- ためになる回答
評価が高い回答ほどページの上位に表示されます。
-
回答の評価を下げる
下記のような回答は推奨されていません。
- 間違っている回答
- 質問の回答になっていない投稿
- スパムや攻撃的な表現を用いた投稿
評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。
+2
GETもPOSTもデータをクライアント側からサーバー側に
送る際のやり方のことで、英語自体の意味は考えない方がいい。
で、HTMLのFORMタグのMETHODで指定するのがそれですね。
地味ですが、CGIの基礎から勉強するといいと思います。
投稿
-
回答の評価を上げる
以下のような回答は評価を上げましょう
- 正しい回答
- わかりやすい回答
- ためになる回答
評価が高い回答ほどページの上位に表示されます。
-
回答の評価を下げる
下記のような回答は推奨されていません。
- 間違っている回答
- 質問の回答になっていない投稿
- スパムや攻撃的な表現を用いた投稿
評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。
checkベストアンサー
+1
GET も POST も、本来は HTTP(S) におけるコマンドのようなものです。
GET は「URL で要求したコンテンツを取得する」で、
POST は「URL で指定したコンテンツにデータを送る」というのが本来の役割です。
※POST は必ずしも結果を返すとは限らない
GET のように、URL にパラメータ(?以降の文字列)を与えて投げた場合、サーバ側でパラメータを解釈して適切なコンテンツを選んで返しています。ただし URL に記述できる文字の種別や長さの制限があるため、あまり大量のパラメータを付けることはできませんし、バイナリデータ(ファイルなど)を送るのにも適していません。
そのような場合は POST を使います。
ajax では、GET なり POST なりでサーバに要求を行って結果を返してもらい、それを受け取った側で加工して画面に反映させる、わけです。要求する側(クライアント)と返却する側(サーバ)とでインタフェースを合わせておかねばならないのは当然のことですね。
※サーバ側からみると、GET で来ても POST で来ても、パラメータをどう取り出すかの違いくらいですので、そこだけ別々に処理して実処理は共通、なんてのはよくありますが、それは「GET で要求されたリクエストを POST で処理する」ではないです。
投稿
-
回答の評価を上げる
以下のような回答は評価を上げましょう
- 正しい回答
- わかりやすい回答
- ためになる回答
評価が高い回答ほどページの上位に表示されます。
-
回答の評価を下げる
下記のような回答は推奨されていません。
- 間違っている回答
- 質問の回答になっていない投稿
- スパムや攻撃的な表現を用いた投稿
評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。
+1
urlを'/menu/list'などとして、jsonデータをpostすると思うのですが、この時は、サーバーサイドでは/menu/listをgetしているのでしょうか?
そのようなことはあり得ません。
クライアントから POST 要求をかければサーバーでは POST 要求として受けて処置します。JSON データを送信する場合はコンテンツの中に含めて送信します。
また、データを取得する際にgetを使う際は、サーバーサイドではpostして、フロントサイドでgetするということなのでしょうか?
それもあり得ません。
クライアントから GET 要求をかければサーバーでは GET 要求として受けて処置します。クライアントから何らかの情報をサーバーに送信する必要がある場合はクエリ文字列として URL に含めて送信します。
Ajax を使っての GET と POST の使い分けは以下の記事のようにするのが普通だと思います。
jQuery - AJAX get() and post() Methods
https://www.w3schools.com/jquery/jquery_ajax_get_post.asp
抜粋すると、
• GET - Requests data from a specified resource
• POST - Submits data to be processed to a specified resource
ということです。
具体例は、Web API 側に WCF をクライアント側に jQuery Ajax を使用した場合ですが、以下の記事の「(3) WCF AJAX サービスへのアクセス」というところを見てください。
WCF と jQuery AJAX
http://surferonwww.info/BlogEngine/post/2015/10/15/wcf-and-jquery-ajax.aspx
なお、今回の質問とは直接関係ないことですが、JSON サービスを GET で要求するのは潜在的なセキュリティ上のリスクがあるそうです。詳しくは上に紹介した記事の「(2) AJAX 互換サービス コントラクトの作成」の最後の方に書いてありますので、興味があれば読んでください。
投稿
-
回答の評価を上げる
以下のような回答は評価を上げましょう
- 正しい回答
- わかりやすい回答
- ためになる回答
評価が高い回答ほどページの上位に表示されます。
-
回答の評価を下げる
下記のような回答は推奨されていません。
- 間違っている回答
- 質問の回答になっていない投稿
- スパムや攻撃的な表現を用いた投稿
評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。
15分調べてもわからないことは、teratailで質問しよう!
- ただいまの回答率 88.19%
- 質問をまとめることで、思考を整理して素早く解決
- テンプレート機能で、簡単に質問をまとめられる