Java中的?HTTP?協(xié)議原理詳解
前言
HTTP(Hyper Text Transfer Protocol)超文本傳輸協(xié)議,下文簡稱 HTTP,它的作用是用于實現(xiàn)服務(wù)器端和客戶端的數(shù)據(jù)傳輸?shù)摹K梢詡鬏斎我獾臄?shù)據(jù)類型,如文本、HTML、圖片、文件、聲音等類型。 簡單來說,HTTP 的作用就像一個“快遞”一樣,用來承載客戶端(瀏覽器)和服務(wù)器端的數(shù)據(jù)傳輸,
如下圖所示:
1.HTTP 特點
HTTP 的主要特點有以下 5 個:
- 簡單快速:客戶端向服務(wù)器端發(fā)送請求時,只需傳遞請求方法、路徑和請求參數(shù),因為協(xié)議簡單,所以使得 HTTP 服務(wù)器的程序規(guī)模小,因而通信速度很快。
- 無連接:所謂的無連接指的是,每次連接只處理一個請求。服務(wù)器處理完客戶的請求后,會立即斷開連接。
- 無狀態(tài):HTTP 不會記錄每次請求的身份信息,因此前一次請求和后一次請求相互“不認(rèn)識”。
- 可傳遞任意數(shù)據(jù)類型:HTTP 允許傳輸任意數(shù)據(jù)類型,只需要在請求頭中標(biāo)識數(shù)據(jù)類型 Content-Type 即可。
一對一通訊:每次 HTTP 請求,都是一個客戶端對應(yīng)一個服務(wù)器端。
2.HTTP 組成
HTTP 是由以下 2 部分組成的:
- 請求對象 Request(客戶端請求)。
- 響應(yīng)對象 Response(服務(wù)器響應(yīng))。
每次 HTTP 請求都是由一次請求和一次響應(yīng)構(gòu)成的,如下圖所示:
2.1 請求對象
請求對象包含 4 部分內(nèi)容:
- 請求行
- 請求報頭
- 空行
- 請求正文
如下圖所示:
2.1.1 請求行
請求行包含了以下 3 部分內(nèi)容:
- 請求類型 Method,如 GET。
- 請求的 URL 地址,
- HTTP 版本號,如 HTTP/1.1。
其中,所有的請求類型如下:
2.1.2 請求報頭
請求報頭是在發(fā)送請求時,描述更多的請求信息的,它以 "name: value" 的形式存在的,每個請求報頭占一行。 常見的請求報頭有以下幾個:
- Host:表示服務(wù)器端的地址和端口號。
- Content-Type:用于描述請求正文中的數(shù)據(jù)類型,常見的類型有:json 格式的 application/json、表單格式的 application/x-www-form-urlencoded、文件格式的 multipart/form-data 等。
- Content-Length:用于描述請求正文中的數(shù)據(jù)長度,需要注意的是,這里的數(shù)據(jù)長度統(tǒng)計單位為字節(jié)而非字符。
- User-Agent:用戶代理信息,比如訪問用戶的系統(tǒng)信息,瀏覽器類型和版本信息等。
2.1.3 空行
一個沒有任何內(nèi)容的空行,用于分隔請求報頭和請求正文的特殊組成部分。
2.1.4 請求正文
業(yè)務(wù)系統(tǒng)中要傳遞參數(shù)。
2.2 響應(yīng)對象
響應(yīng)對象也是由 4 部分內(nèi)容組成的:
- 狀態(tài)行
- 響應(yīng)報頭
- 空行
- 響應(yīng)正文
如下圖所示:
2.2.1 狀態(tài)行
狀態(tài)行用于描述服務(wù)器的返回狀態(tài),它由 3 部分組成:
- HTTP 版本號,如 HTTP/1.1。
- 狀態(tài)碼,如 200。
- 狀態(tài)描述信息,如 OK。
常見的狀態(tài)碼有以下幾個:
- 200:返回成功。
- 301:永久重定向。
- 302:臨時重定向。
- 404:未找到頁面。
- 500:服務(wù)器程序出錯。
2.2.2 響應(yīng)報頭
響應(yīng)報頭和請求報頭類似,也是以 "name: value" 的形式存在的,每個報頭占一行。 常見的報頭有 Content-Type,它是用于描述響應(yīng)正文的數(shù)據(jù)類型的,常見的數(shù)據(jù)類型有:json 格式的 application/json 和 HTML 格式的 text/html。
2.2.3 空行
一個沒有任何內(nèi)容的空行,用于分隔狀態(tài)行和響應(yīng)正文的特殊組成部分。
2.2.4 響應(yīng)正文
返回給客戶端的所有數(shù)據(jù)。
總結(jié)
HTTP 超文本傳輸協(xié)議,用于實現(xiàn)服務(wù)器端和客戶端的數(shù)據(jù)傳輸。它的特點是簡單快速、無連接、無狀態(tài)、可傳遞任意數(shù)據(jù)類型和一對一通訊。HTTP 協(xié)議由兩部分組成:請求對象 Request 和響應(yīng)對象 Response。
到此這篇關(guān)于Java中的 HTTP 協(xié)議原理詳解的文章就介紹到這了,更多相關(guān)Java HTTP 協(xié)議內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JAVA中通過Hibernate-Validation進(jìn)行參數(shù)驗證
這篇文章主要介紹了JAVA中通過Hibernate-Validation進(jìn)行參數(shù)驗證,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04Java-Redis-Redisson分布式鎖的功能使用及實現(xiàn)
這篇文章主要介紹了Java-Redis-Redisson-分布式鎖的功能使用及實現(xiàn),本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-08-08SpringBoot如何通過@Profile注解配置多環(huán)境
在Spring中,可以使用配置文件的方式來指定不同環(huán)境下所需要的配置信息,本文給大家介紹SpringBoot如何通過@Profile注解配置多環(huán)境,感興趣的朋友跟隨小編一起看看吧2023-06-06Java編程通過list接口實現(xiàn)數(shù)據(jù)的增刪改查代碼示例
這篇文章是介紹Java編程基礎(chǔ)方面的內(nèi)容,涉及l(fā)ist接口的操作,通過list接口實現(xiàn)對數(shù)據(jù)的增刪改查的相關(guān)代碼,具有一定參考價值,需要的朋友可以了解下。2017-10-10