Http協(xié)議與TCP協(xié)議

Paste_Image.png

Http協(xié)議

HTTP 超文本傳輸協(xié)議,是一個(gè)基于請求與響應(yīng)模式的、無狀態(tài)的、應(yīng)用層協(xié)議。

Http報(bào)文介紹

Http請求報(bào)文?由請求行(request line)、請求頭部(header)和請求數(shù)據(jù)組成,下圖給出了請求報(bào)文的一般格式。

Paste_Image.png
  • 1、請求行
    由3部分組成,分別為:請求方法URL以及協(xié)議版本,之間由空格分隔
    請求方法包括GETHEADPUTPOSTTRACEOPTIONS、DELETE以及擴(kuò)展方法,當(dāng)然并不是所有的服務(wù)器都實(shí)現(xiàn)了所有的方法,部分方法即便支持,處于安全性的考慮也是不可用的
    協(xié)議版本的格式為:HTTP/主版本號.次版本號,常用的有HTTP/1.0和HTTP/1.1
    HTTP1.0定義了三種請求方法: GET, POSTHEAD方法。
    HTTP1.1新增了五種請求方法:OPTIONS, PUT, DELETE, TRACECONNECT 方法。
Paste_Image.png
  • 2,請求頭部
    請求頭部為請求報(bào)文添加了一些附加信息,由“名/值”對組成,每行一對,名和值之間使用冒號分隔

常見請求頭:


Paste_Image.png

請求頭部的最后會有一個(gè)空行,表示請求頭部結(jié)束,對于請求報(bào)文的組成有另一種說法:請求報(bào)文由請求行請求頭空行請求體四個(gè)部分組成。

  • 3、請求正文
    可選部分,比如GET請求就沒有請求正文
    GET請求示例:
Paste_Image.png

POST請求示例:

Paste_Image.png

Http響應(yīng)報(bào)文
Http響應(yīng)報(bào)文由狀態(tài)行、響應(yīng)頭部、響應(yīng)正文3部分組成

Paste_Image.png
  • 1、狀態(tài)行
    由3部分組成,分別為:協(xié)議版本,狀態(tài)碼,狀態(tài)碼描述,之間由空格分隔
    狀態(tài)代碼為3位數(shù)字,200299的狀態(tài)碼表示成功,300399的狀態(tài)碼指資源重定向,400499的狀態(tài)碼指客戶端請求出錯,500599的狀態(tài)碼指服務(wù)端出錯(HTTP/1.1向協(xié)議中引入了信息性狀態(tài)碼,范圍100~199)
    狀態(tài)碼可參考HTTP狀態(tài)碼

  • 響應(yīng)頭部
    常見響應(yīng)頭部:

響應(yīng)頭 ?說明
Allow 服務(wù)器支持哪些請求方法(如GET、POST等)
Content-Encoding 文檔的編碼(Encode)方法。只有在解碼之后才可以得到Content-Type頭指定的內(nèi)容類型。利用gzip壓縮文檔能夠顯著地減少HTML文檔的下載時(shí)間。Java的GZIPOutputStream可以很方便地進(jìn)行g(shù)zip壓縮,但只有Unix上的Netscape和Windows上的IE 4、IE 5才支持它。因此,Servlet應(yīng)該通過查看Accept-Encoding頭(即request.getHeader("Accept-Encoding"))檢查瀏覽器是否支持gzip,為支持gzip的瀏覽器返回經(jīng)gzip壓縮的HTML頁面,為其他瀏覽器返回普通頁面。
Content-Length 表示內(nèi)容長度。只有當(dāng)瀏覽器使用持久HTTP連接時(shí)才需要這個(gè)數(shù)據(jù)。如果你想要利用持久連接的優(yōu)勢,可以把輸出文檔寫入 ByteArrayOutputStream,完成后查看其大小,然后把該值放入Content-Length頭,最后通過byteArrayStream.writeTo(response.getOutputStream()發(fā)送內(nèi)容。
Content-Type 表示后面的文檔屬于什么MIME類型。Servlet默認(rèn)為text/plain,但通常需要顯式地指定為text/html。由于經(jīng)常要設(shè)置Content-Type,因此HttpServletResponse提供了一個(gè)專用的方法setContentType。
Server 服務(wù)器應(yīng)用程序軟件的名稱和版本
Content-Charset 響應(yīng)正文使用的編碼
Content-Language 響應(yīng)正文使用的語言

響應(yīng)示例:

Paste_Image.png

Content-Type
Content-Type,http內(nèi)容類型,一般是指網(wǎng)頁中存在Content-Type。用于定義網(wǎng)絡(luò)文件的類型和網(wǎng)頁編碼,決定文件接收方以什么樣的形式,什么編碼讀取這個(gè)文件。
Content-Type默認(rèn)類型是“text/html”。
Content-type類型有很多種,具體可參考HTTP content-type 對照表

URL
URL全名為Uniform Resource Locator(統(tǒng)一資源定位),通過描述資源的位置來標(biāo)識資源

  • URI、URL和URN之間的區(qū)別
    URI全名為Uniform Resource Indentifier(統(tǒng)一資源標(biāo)識),用來唯一的標(biāo)識一個(gè)資源,是一個(gè)通用的概。URI由兩個(gè)主要的子集URL和URN組成。
    URL全名為Uniform Resource Locator(統(tǒng)一資源定位),通過描述資源的位置來標(biāo)識資源
    URN全名為Uniform Resource Name(統(tǒng)一資源命名),通過資源的名字來標(biāo)識資源,與其所處的位置無關(guān),這樣即使資源的位置發(fā)生變動,其URN也不會變化

HTTP規(guī)范將更通用的概念URI作為其資源標(biāo)識符,但是實(shí)際上,HTTP應(yīng)用程序處理的只是URI的URL子集

-關(guān)于BIO和NIO的理解

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,431評論 6 544
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,637評論 3 429
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 178,555評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,900評論 1 318
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 72,629評論 6 412
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,976評論 1 328
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,976評論 3 448
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 43,139評論 0 290
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,686評論 1 336
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 41,411評論 3 358
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 43,641評論 1 374
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,129評論 5 364
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,820評論 3 350
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,233評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,567評論 1 295
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 52,362評論 3 400
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 48,604評論 2 380

推薦閱讀更多精彩內(nèi)容