01_HTTP协议
文章目錄
- 前言
- 1. 概述
- 2. http請求與http響應
- 2.1 http請求
- 2.2 http響應
- 3. URL(scheme:[//[user:password@]host[:port]][/]path[?query][#fragment])
- 3.1 協議(scheme)
- 3.2 主機(host)與端口(port)
- 3.3 路徑(path)、查詢字符串(?query)、錨點(#fragment)
- 4. Http請求頭
前言
當前大部分的應用都是基于B/S架構的,而這其中主流的是基于http通信協議的。所以對于一個web開發者來說,http協議的重要性不言而喻。
1. 概述
HTTP協議是一種被大多數web應用程序所使用的的協議
- HTTP 數據的收發是基于TCP/IP協議的
- HTTP 數據主要是文本,雖然請求體中的中的數據可以是二進制的
兩個步驟
- 請求: 客戶機向服務器請求文檔。“文檔”可以是任何類型的文件。
- 響應: 服務器用請求的文檔(或備用響應)響應客戶機請求。
其整個知識點如下:
HTTP協議是web應用開發的基石
2. http請求與http響應
2.1 http請求
一個HTTP請求是純文本內容的。它包含三個部分請求行、請求頭、請求體
請求行:這個是http請求的第一行,整個請求行又分為三部分:URL,方法,版本
- URL:代表請求的文檔
- 方法:有put, get, delete, head, options, post, tract, connect
- 版本:該http請求使用http協議版本,一般有HTTP/1.0 或者 HTTP/1.1
請求頭:允許額外信息的可選行。每一行都是名稱-值對
空行:用于將正文與標題分開
請求體:可選字節(一般用來承擔業務數據).
2.2 http響應
一個HTTP響應也是由文本行組成
狀態行: 第一行,由三個空格分隔的元素組成。.
- 版本: 響應的HTTP版本
- 狀態碼: 一個三位數代碼
- 描述: 狀態碼的文本描述
響應頭:允許在客戶機和服務器之間交換數據的可選行。
響應體: 必須用空行與標題分隔的可選行
3. URL(scheme:[//[user:password@]host[:port]][/]path[?query][#fragment])
我們可以把因特網當做一個巨大的,正在擴張的城市。這個城市中所有的東西都應該有一個標準化的名字,以幫助人們能夠很塊的找到這個城市中的各種資源。當城市中的所有東西都認同并服從這個標準后,大家才能很方便的共享這座城市的資源了。
比如你需要你的朋友A幫你獲取到位于xxx大道xxx街的xxx圖書館中二樓計算機室的xxx書架上的xxx書(標準化的名字)的時候。你的朋友A立即就知道你是什么意思了。
而URL就是因特網上的資源的標準化名稱。
URL是統一資源定位符的縮寫。它是一個具有特殊含義的字符串,其格式如下
scheme:[//[user:password@]host[:port]][/]path[?query][#fragment]
可以看到整個URL分為以下七個部分
3.1 協議(scheme)
- 定義了URL余下部分的名稱空間、用途和語法
- 不區分大小寫
比如你在瀏覽器地址欄中鍵入http://example.org:80,瀏覽器就會通過80端口向主機example.org發送HTTP請求。
如果你在瀏覽器地址欄中鍵入mailto:bob@example.com,那么瀏覽器就會向bob@example.com發送郵件來執行你的指令
再比如你在瀏覽器中鍵入ftp://IP/Download/,那么你的瀏覽器就可以通過ftp協議獲取到這個ip指向服務器的資源。
3.2 主機(host)與端口(port)
URL的目標位置,相當于前面的拿書的那個例子中圖書館的位置信息(位于xxx大道xxx街的xxx圖書館)。
這一段字符串的作用是通過它能準確定位到因特網中某臺主機。
host字段有兩種:ip和域名
域名是ip地址的替代,瀏覽器會通過使用DNS來獲取域名對應的IP地址。
IPV4: 32比特(4組,每組8比特)
IPV6: 128 比特
表示如果省略將接收請求的服務器應用程序,則使用特定于方案的默認值.
3000: HTTP Nodejs server
8080: HTTP Tomcat server
22: Secure Shell (SSH)
80: HTTP default
443: HTTP Secure (HTTPS)
3.3 路徑(path)、查詢字符串(?query)、錨點(#fragment)
路徑:
資源的位置。相當于前面拿書的例子中圖書在圖書館中的位置信息(二樓計算機室的xxx書架上的xxx書)
該字段區分大小寫(有些服務器不區分大小寫).
查詢字符串:
還是用拿書的例子來說,比如需要的書有很多種版本(第一版、第二版之類的)。所以在后面加上一些信息(版本為第五版,封面為白色的)。
以?起頭,后面跟上鍵值對,多個鍵值對之間以&符號區別。
舉個例子
后邊wd=htttp協議片段&rsv_spt=1&rsv_iqid=0xf5310479000d154e&issp=1&f=8&rsv_bp=1&rsv_idx=2就是查詢字段。
錨點
拿前面的拿書的例子來說,如果我需要的東西只是書中的某一段怎么辦,按道理是可以放在查詢字段中的,但是它與普通查詢字段有不一樣,因為這時候書(資源)已經找到了。所以可以在后面在加上一個字段,專門用來定位的。
例子:
一個比較常見的例子就是百度百科最右邊的目錄
4. Http請求頭
由于不能將所有的信息放在請求行中,那樣會讓請求行顯得十分冗長。所以開辟一個空間用來攜帶額外的信息,那么這個空間就是http請求頭。就我目前對http協議的理解,http請求頭中的信息是用來描述本次請求以及期待響應的信息,并不涉及業務功能。比如Accept就是向服務器表明瀏覽器可以接受的文本類型。
由于是用來描述請求與期待響應的,所以請求頭中信息的組織形式為鍵-值。
請求頭中常用的鍵以及其意義
| Accept | 瀏覽器可以接受的文本類型 |
| Accept-Charset | 瀏覽器需要的字符集(接觸比較少) |
| Accept-Encoding | 瀏覽器接受的字符編碼 |
| Accept-Language | 瀏覽器接受的語言 |
| Content-Length | 請求正文的長度 |
| Content-Type | 請求正文的類型,文本、html等等 |
總結
- 上一篇: TensorFlow学习笔记之五(卷积神
- 下一篇: 问题之JVM_Bind