絕大多數(shù)web應(yīng)用都是簡歷在HTTP協(xié)議的基礎(chǔ)上的,所以學(xué)習(xí)HTTP有助于我們更好的進(jìn)行網(wǎng)絡(luò)開發(fā)。
IP網(wǎng)絡(luò)中每臺電腦都有一個唯一的IP地址。IP地址是一個邏輯地址。英特網(wǎng)中IP地址具有全球唯一性。32位,4個字節(jié),通常用十進(jìn)制數(shù)表示,如:192.168.1.16。
為了進(jìn)行網(wǎng)絡(luò)中的數(shù)據(jù)交換,而建立的規(guī)則,標(biāo)準(zhǔn)或約定。不同層有各自不同的協(xié)議。
分層方法,把網(wǎng)絡(luò)互聯(lián)問題劃分為若干個較小的,單一的問題,在不同層上予以解決。
OSI將網(wǎng)絡(luò)的不同功能劃分為7層。
開發(fā)主要跟應(yīng)用層打交到。
對等層實(shí)體之間虛擬通信。下層向上層提供服務(wù),實(shí)際通信在最底層完成。
應(yīng)用層:遠(yuǎn)程登錄協(xié)議(telnet)、文件傳輸協(xié)議(FTP)、超文本傳輸協(xié)議(HTTP)、域名服務(wù)(DNS)、簡單郵件傳輸協(xié)議(SMTP)、郵局協(xié)議(POP3)。
傳輸層:傳輸控制協(xié)議(TCP)、用戶數(shù)據(jù)報(bào)協(xié)議(UDP)。
面向連接的保證可靠傳輸?shù)膮f(xié)議。一旦連接建立起來,雙方的socket就可以按統(tǒng)一的格式,傳送大量的數(shù)據(jù)。
UDP是一個不可靠的協(xié)議,發(fā)送方發(fā)送的數(shù)據(jù)報(bào),并不是按相同的次序答接對方。每次傳送數(shù)據(jù)包有大小限制,每個包在64K之間。
l 可靠傳輸需要付出代價,TCP傳輸效率不如UDP高。
l 許多應(yīng)用中并不需要使用可靠的TCP傳輸方式,比如網(wǎng)絡(luò)視頻只用保證連貫性就可以了。這種情況顯然UDP更合理。
互聯(lián)網(wǎng)傳輸?shù)臄?shù)據(jù)都包括IP和端口號。IP地址用來標(biāo)識網(wǎng)絡(luò)上的計(jì)算機(jī),端口用來指明該IP地址計(jì)算機(jī)上的應(yīng)用程序。端口使用16位的數(shù)字表示,范圍是0~65535,1024以下的端口號保留給預(yù)定義服務(wù)。HTTP使用80端口。
l 一臺計(jì)算機(jī)發(fā)送數(shù)據(jù)到另一臺計(jì)算機(jī),數(shù)據(jù)必須打包,我們管打包過程叫做封裝。
l 封裝就是在數(shù)據(jù)前面加上特定的協(xié)議頭。
l HTTP是超文本傳輸協(xié)議,目前的版本是1.1。
l HTTP是應(yīng)用層協(xié)議,瀏覽器和服務(wù)器之間通過HTTP在INTERNET上進(jìn)行數(shù)據(jù)發(fā)送和接受。
l HTTP是一個基于請求/響應(yīng)模式的,無狀態(tài)的協(xié)議。
1. 客戶端發(fā)起連接
2. 客戶端發(fā)送請求
3. 服務(wù)器響應(yīng)請求
4. 服務(wù)器關(guān)閉連接
開銷大,造成INTERNET堵塞。
持續(xù)連接,發(fā)送請求可以在此得到回應(yīng),一直在一個連接里面??蛻舳税l(fā)送多個請求,不用對每次請求都重新建立連接。
1. 客戶端建立連接
2. 客戶端發(fā)出第一次請求
3. 客戶端發(fā)出第N次請求
4. 服務(wù)端回送第一次請求
5. 服務(wù)端回送第N次請求
6. 客戶端發(fā)出關(guān)閉連接請求
7. 服務(wù)端關(guān)閉連接
l URI純粹的符號結(jié)構(gòu),用于指定構(gòu)成web資源的字符串的各個不同部分。
l URL是一種特殊類型的URI,它包含了用于查找某個資源的足夠的信息。
l 客戶端通過發(fā)送HTTP請求向服務(wù)器請求對資源的訪問。
l HTTP請求由三部分組成,分別是:請求行,信息報(bào)頭,請求正文。
l 以一個方法符號開頭,后面跟著請求URI和協(xié)議的版本,以回車換行結(jié)尾。
l 格式:Method Request-URI HTTP-version
① Method 表示請求方法,常用的有get和post。
② Request-URI 是一個統(tǒng)一資源標(biāo)識符。標(biāo)識了要請求的資源。
③ HTTP-version 表示請求的HTTP協(xié)議的版本。
l 如:GET /test.html HTTP/1.1
l GET方法用于獲取由Request-URI所標(biāo)識的資源的信息。
l 我們通過瀏覽器直接輸入網(wǎng)址的方式去訪問網(wǎng)頁,就是GET方法。
l POST方法用于向服務(wù)器發(fā)送請求,要求服務(wù)器接受附在請求后面的數(shù)據(jù)。POST方法在表單提交時用的最多。
l HEAD方法與GET方法幾乎是一樣的,他們的區(qū)別在于HEAD方法只是請求消息報(bào)頭,而不是完整的內(nèi)容。
l GET和POST的區(qū)別:處理的方式不一樣,處理的方法不一樣,地址欄呈現(xiàn)的結(jié)果不一樣。
l Get:把沒有實(shí)體內(nèi)容,會把提交的數(shù)據(jù)加到url地址后面。點(diǎn)擊超鏈接敲url地址都是get
l Post:如果我的提交的數(shù)據(jù)不改變服務(wù)器端的狀態(tài)就用get(get會緩存)。提交的數(shù)據(jù)改變服務(wù)器端的狀態(tài)就用post
l 在接收和解釋請求消息后,服務(wù)器會返回一個HTTP響應(yīng)消息。
l 與HTTP請求類似,HTTP響應(yīng)也是由三個部分組成,分別是:狀態(tài)行,消息報(bào)頭,響應(yīng)正文。
l 由協(xié)議版本,數(shù)字形式的狀態(tài)代碼,相應(yīng)的狀態(tài)描述組成,各個元素中間以空格分隔,除了結(jié)尾回車換行,不允許出現(xiàn)回車換行字符。
l 如:HTTP/1.1 200 OK
對于請求消息,開始行就是請求行,對于響應(yīng)消息,開始行就是狀態(tài)行。
聯(lián)系客服