[ 通常表示 ]  [ 簡易表示 ]  [ シンプル表示 ]

「分かりそう」で「分からない」でも「分かった」気になれるIT用語辞典イメージぴよ画像「分かりそう」で「分からない」でも「分かった」気になれるIT用語辞典

HTTPレスポンス

pointこの用語のポイント

point「このページをちょうだい」なお願いに対する返事だよ

pointホームページの話で出てくるよ

スポンサーリンク

簡単に書くよ

HTTPレスポンスとは

HTTPリクエストに対するレスポンス。
もう少し噛み砕いて書くと

ホームページを見るソフト(Webブラウザ)からホームページのファイルが置いてあるコンピュータ(Webサーバ)に対して出される「このページをちょうだい」なお願いに対するWebサーバさんからの返事
です。

image piyo

詳しく書くよ

順番に見ていきましょう。
まずは予備知識として

ホームページが表示される流れ
HTTP
HTTPリクエスト


について簡単に説明します。
「そんなの説明されなくても知ってるよ!」な人は、適当に読み飛ばしてください。

あなたがホームページを見ようとすると、まず、ホームページを見るときに使うソフトWebブラウザ)からホームページのファイルが置いてあるコンピュータ(Webサーバ)に対して「このページをおくれ」なお願いが出されます。

HTTPレスポンス

そのお願いに対して、WebサーバさんからWebブラウザさんに「ほれ、そのページだよ」とお返事がきます。

HTTPレスポンス2

お返事を受け取ったWebブラウザさんは、受け取った内容(ホームページのファイル)を画面上に表示してくれます。

HTTPレスポンス3

これが、ホームページが表示されるときの流れです。

この流れにおいて、WebブラウザさんとWebサーバさんは、やり取りをしました。
このやり取りで使われるお約束事を「HTTP」と言います。
HTTPは「ホームページのファイルとかを受け渡しするときに使うお約束事」です。

HTTPレスポンス4

WebブラウザさんからWebサーバさんに出される「このページをおくれ」なお願いは「HTTPリクエスト」と言います。

HTTPレスポンス5

リクエストは「これをやってよー!」なお願いです。
カッコ付けて「要求」などと表現されることもあります。

WebブラウザさんからWebサーバさんに出される「このページをおくれ」なお願いはリクエストです。

ただし、単に「リクエスト」と表現すると、何のリクエストなのかが、はっきりしません。
通信したいです」も「今日の晩御飯はトンカツが食べたいな~」も「あの曲を流してくださ~い」もリクエストと呼べますからね。

そこで頭に「HTTP」を付けて「HTTPリクエスト」と表現するのです。
そうすれば

HTTPのリクエストなのね
 ↓
HTTPってことはホームページ関連ですか
 ↓
ホームページの話で出てくるリクエストのことね


と分かります。

以上を踏まえて、HTTPリクエストに対する返事、Webサーバさんから返ってくる「ほれ、そのページだよ」なお返事が「HTTPレスポンス」です。

HTTPレスポンス6

レスポンスはリクエストに対する反応(返事)です。
カッコ付けて「応答」などと表現されることもあります。

HTTPリクエストに対する反応(返事)だからHTTPレスポンスです。

HTTPリクエスト:「このページをおくれ」なお願い
HTTPレスポンス:「ほれ、そのページだよ」なお返事


となります。

HTTPレスポンス7

HTTPレスポンスは3つの部品から成り立っています。

1.HTTPステータスライン(ステータスライン)
2.HTTPレスポンスヘッダ(ヘッダ)
3.HTTPレスポンスボディ(レスポンスボディ)


の3つです。
構造としては

「ステータスライン」
「ヘッダ」
空行CRLF】)
「レスポンスボディ」


のようになっています。

HTTPレスポンス8

実際のHTTPレスポンスは、例えば以下のような内容になっています。

HTTP/1.1 200 OK\r\n
Server: nginx\r\n
Date: Tue, 11 Jul 2017 09:23:07 GMT\r\n
Content-Type: text/html\r\n
Transfer-Encoding: chunked\r\n
Connection: keep-alive\r\n
\r\n
<!DOCTYPE html>\r\n
<html lang="ja">\r\n
<head>\r\n
\t<meta http-equiv="content-type" content="text/html; charset=UTF-8" />\r\n
\t<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">\r\n
\r\n
\r\n
\t<meta name="keywords" content="\350\276\236\345\205\270,IT,\347\224\250\350\252\236,\345\210\235\345\277\203\350\200\205">\r\n
\t<meta name="author" content="Makoto Sasaki">\r\n
\t<meta name="copyright" content="Copyright PCS">\r\n
\r\n
\t<meta name="application-name" content="\343\202\217\343\202\217\343\202\217IT\347\224\250\350\252\236\350\276\236\345\205\270"/>\r\n
\t<link rel="stylesheet" href="css/style.css?ver=00109">\r\n
\t<link rel="stylesheet" href="css/search.css?ver=00109">\r\n
\t<script src="./js/jquery-1.7.2.min.js?ver=00109"></script>\r\n
\t<script src="./js/common.js?ver=00109"></script>\r\n
</head>\r\n
<body>\r\n

(中略)

</body>\r\n
</html>\r\n
\r\n


ごちゃごちゃしていて分かりにくいですが、1行目の

HTTP/1.1 200 OK\r\n

がHTTPステータスラインです。
HTTPステータスラインには「HTTPリクエストの結果」が、ざっくりと書かれています。
この例では

「HTTP/1.1」で「200 OK」が返ってきたよ!

と書いてあります。

2行目以降の

Server: nginx\r\n
Date: Tue, 11 Jul 2017 09:23:07 GMT\r\n
Content-Type: text/html\r\n
Transfer-Encoding: chunked\r\n
Connection: keep-alive\r\n


がHTTPレスポンスヘッダです。
HTTPレスポンスヘッダには「HTTPステータスラインに書ききれないレスポンスの情報」が、ごちゃごちゃと書かれています。

空行を意味する

\r\n

を挟んで、最後の

<!DOCTYPE html>\r\n
<html lang="ja">\r\n
<head>\r\n
\t<meta http-equiv="content-type" content="text/html; charset=UTF-8" />\r\n
\t<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">\r\n
\r\n
\r\n
\t<meta name="keywords" content="\350\276\236\345\205\270,IT,\347\224\250\350\252\236,\345\210\235\345\277\203\350\200\205">\r\n
\t<meta name="author" content="Makoto Sasaki">\r\n
\t<meta name="copyright" content="Copyright PCS">\r\n
\r\n
\t<meta name="application-name" content="\343\202\217\343\202\217\343\202\217IT\347\224\250\350\252\236\350\276\236\345\205\270"/>\r\n
\t<link rel="stylesheet" href="css/style.css?ver=00109">\r\n
\t<link rel="stylesheet" href="css/search.css?ver=00109">\r\n
\t<script src="./js/jquery-1.7.2.min.js?ver=00109"></script>\r\n
\t<script src="./js/common.js?ver=00109"></script>\r\n
</head>\r\n
<body>\r\n

(中略)

</body>\r\n
</html>\r\n
\r\n


がHTTPレスポンスボディです。
HTTPレスポンスボディには「ほれ、そのページだよ」の「そのページ」が入っています。
ホームページの中身ですね。

これがHTTPレスポンスの構造です。
繰り返しになりますが

「ステータスライン」
「ヘッダ」
(空行【CR+LF】)
「レスポンスボディ」


のようになっています。

image piyo2

一言でまとめるよ

まぁ「HTTPレスポンス」って単語が出てきたら「ホームページの話で出てくる『このページをちょうだい』なお願いに対するお返事なんだな~」と、お考えください。

一番上に戻るよ
スポンサーリンク