亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

http基礎教程

2019-11-14 10:21:39
字體:
來源:轉載
供稿:網友
引用學習Web開發不好好學習HTTP報文,將會“打拳不練功,到老一場空”,你花在犯迷糊上的時間比你沉下心來學習HTTP的時間肯定會多很多。

HTTP請求報文解剖

HTTP請求報文由3部分組成(請求行+請求頭+請求體):  下面是一個實際的請求報文:  ①是請求方法,GET和POST是最常見的HTTP方法,除此以外還包括DELETE、HEAD、OPTIONS、PUT、TRACE。不過,當前的大多數瀏覽器只支持GET和POST,SPRing 3.0提供了一個HiddenHttpMethodFilter,允許你通過“_method”的表單參數指定這些特殊的HTTP方法(實際上還是通過POST提交表單)。服務端配置了HiddenHttpMethodFilter后,Spring會根據_method參數指定的值模擬出相應的HTTP方法,這樣,就可以使用這些HTTP方法對處理方法進行映射了。 ②為請求對應的URL地址,它和報文頭的Host屬性組成完整的請求URL,③是協議名稱及版本號。 ④是HTTP的報文頭,報文頭包含若干個屬性,格式為“屬性名:屬性值”,服務端據此獲取客戶端的信息。 ⑤是報文體,它將一個頁面表單中的組件值通過param1=value1&param2=value2的鍵值對形式編碼成一個格式化串,它承載多個請求參數的數據。不但報文體可以傳遞請求參數,請求URL也可以通過類似于“/chapter15/user.html? param1=value1&param2=value2”的方式傳遞請求參數。 對照上面的請求報文,我們把它進一步分解,你可以看到一幅更詳細的結構圖:  引用HttpWatch是強大的網頁數據分析工具,安裝后將集成到Internet Explorer工具欄中。它不用代理服務器或一些復雜的網絡監控工具,就能抓取請求及響應的完整信息,包括Cookies、消息頭、查詢參數、響應報文等,是Web應用開發人員的必備工具。

HTTP請求報文頭屬性

報文頭屬性是什么東西呢?我們不妨以一個小故事來說明吧。 引用快到中午了,張三豐不想去食堂吃飯,于是打電話叫外賣:老板,我要一份[魚香肉絲],要12:30之前給我送過來哦,我在江湖湖公司研發部,叫張三豐。這里,你要[魚香肉絲]相當于HTTP報文體,而“12:30之前送過來”,你叫“張三豐”等信息就相當于HTTP的報文頭。它們是一些附屬信息,幫忙你和飯店老板順利完成這次交易。 請求HTTP報文和響應HTTP報文都擁有若干個報文關屬性,它們是為協助客戶端及服務端交易的一些附屬信息。 

常見的HTTP請求報文頭屬性

Accept

請求報文可通過一個“Accept”報文頭屬性告訴服務端 客戶端接受什么類型的響應。 

如下報文頭相當于告訴服務端,俺客戶端能夠接受的響應類型僅為純文本數據啊,你丫別發其它什么圖片啊,視頻啊過來,那樣我會歇菜的~~~:

Accept:text/plain Accept屬性的值可以為一個或多個MIME類型的值,關于MIME類型,大家請參考:http://en.wikipedia.org/wiki/MIME_type

Cookie

客戶端的Cookie就是通過這個報文頭屬性傳給服務端的哦!如下所示:
Cookie: $Version=1; Skin=new;jsessionid=5F4771183629C9834F8382E23BE13C4C服務端是怎么知道客戶端的多個請求是隸屬于一個Session呢?注意到后臺的那個jsessionid=5F4771183629C9834F8382E23BE13C4C木有?原來就是通過HTTP請求報文頭的Cookie屬性的jsessionid的值關聯起來的!(當然也可以通過重寫URL的方式將會話ID附帶在每個URL的后面哦)。

Referer

表示這個請求是從哪個URL過來的,假如你通過google搜索出一個商家的廣告頁面,你對這個廣告頁面感興趣,鼠標一點發送一個請求報文到商家的網站,這個請求報文的Referer報文頭屬性值就是http://www.google.com。 引用唐僧到了西天. 如來問:儂是不是從東土大唐來?。?nbsp;唐僧:厲害!你咋知道的! 如來:呵呵,我偷看了你的Referer... 很多貌似神奇的網頁監控軟件(如著名的 我要啦),只要在你的網頁上放上一段javaScript,就可以幫你監控流量,全國訪問客戶的分布情況等報表和圖表,其原理就是通過這個Referer及其它一些HTTP報文頭工作的。

Cache-Control

對緩存進行控制,如一個請求希望響應返回的內容在客戶端要被緩存一年,或不希望被緩存就可以通過這個報文頭達到目的。如以下設置,相當于讓服務端將對應請求返回的響應內容不要在客戶端緩存:
Cache-Control: no-cache 其它請求報文頭屬性 參見:http://en.wikipedia.org/wiki/List_of_HTTP_header_fields

如何訪問請求報文頭

由于請求報文頭是客戶端發過來的,服務端當然只能讀取了,以下是HttpServletRequest一些用于讀取請求報文頭的API:
    //獲取請求報文中的屬性名稱      java.util.Enumeration<java.lang.String>   getHeaderNames();            //獲取指定名稱的報文頭屬性的值      java.lang.String getHeader(java.lang.String name)   由于一些請求報文頭屬性“太著名”了,因此HttpServletRequest為它們提供了VIP的API:
 //獲取報文頭中的Cookie(讀取Cookie的報文頭屬性)   Cookie[]   getCookies() ;    //獲取客戶端本地化信息(讀取 Accept-Language 的報文頭屬性)  java.util.Locale    getLocale()     //獲取請求報文體的長度(讀取Content-Length的報文頭屬性)  int getContentLength();HttpServletRequest可以通過
HttpSession getSession() 獲取請求所關聯的HttpSession,其內部的機理是通過讀取請求報文頭中Cookie屬性的JSESSIONID的值,在服務端的一個會話Map中,根據這個JSESSIONID獲取對應的HttpSession的對象。(這樣,你就不會覺得HttpSession很神秘了吧,你自己也可以做一個類似的會話管理  )

HTTP響應報文解剖 

響應報文結構

HTTP的響應報文也由三部分組成(響應行+響應頭+響應體): 以下是一個實際的HTTP響應報文:  ①報文協議及版本; ②狀態碼及狀態描述; ③響應報文頭,也是由多個屬性組成; ④響應報文體,即我們真正要的“干貨”。

響應狀態碼

和請求報文相比,響應報文多了一個“響應狀態碼”,它以“清晰明確”的語言告訴客戶端本次請求的處理結果。HTTP的響應狀態碼由5段組成: 1xx 消息,一般是告訴客戶端,請求已經收到了,正在處理,別急...2xx 處理成功,一般表示:請求收悉、我明白你要的、請求已受理、已經處理完成等信息.3xx 重定向到其它地方。它讓客戶端再發起一個請求以完成整個處理。4xx 處理發生錯誤,責任在客戶端,如客戶端的請求一個不存在的資源,客戶端未被授權,禁止訪問等。5xx 處理發生錯誤,責任在服務端,如服務端拋出異常,路由出錯,HTTP版本不支持等。以下是幾個常見的狀態碼: 200 OK 你最希望看到的,即處理成功! 303 See Other 我把你redirect到其它的頁面,目標的URL通過響應報文頭的Location告訴你。 引用悟空:師傅給個桃吧,走了一天了 唐僧:我哪有桃??!去王母娘娘那找吧304 Not Modified 告訴客戶端,你請求的這個資源至你上次取得后,并沒有更改,你直接用你本地的緩存吧,我很忙哦,你能不能少來煩我?。?nbsp;404 Not Found 你最不希望看到的,即找不到頁面。如你在google上找到一個頁面,點擊這個鏈接返回404,表示這個頁面已經被網站刪除了,google那邊的記錄只是美好的回憶。 500 Internal Server Error 看到這個錯誤,你就應該查查服務端的日志了,肯定拋出了一堆異常,別睡了,起來改BUG去吧! 其它的狀態碼參見:http://en.wikipedia.org/wiki/List_of_HTTP_status_codes 有些響應碼,Web應用服務器會自動給生成。你可以通過HttpServletResponse的API設置狀態碼:
 //設置狀態碼,狀態碼在HttpServletResponse中通過一系列的常量預定義了,如SC_ACCEPTED,SC_OK  void    setStatus(int sc) 

常見的HTTP響應報文頭屬性 

Cache-Control

響應輸出到客戶端后,服務端通過該報文頭屬告訴客戶端如何控制響應內容的緩存。 下面,的設置讓客戶端對響應內容緩存3600秒,也即在3600秒內,如果客戶再次訪問該資源,直接從客戶端的緩存中返回內容給客戶,不要再從服務端獲?。ó斎唬@個功能是靠客戶端實現的,服務端只是通過這個屬性提示客戶端“應該這么做”,做不做,還是決定于客戶端,如果是自己宣稱支持HTTP的客戶端,則就應該這樣實現)。
Cache-Control: max-age=3600 

ETag

一個代表響應服務端資源(如頁面)版本的報文頭屬性,如果某個服務端資源發生變化了,這個ETag就會相應發生變化。它是Cache-Control的有益補充,可以讓客戶端“更智能”地處理什么時候要從服務端取資源,什么時候可以直接從緩存中返回響應。關于ETag的說明,你可以參見:http://en.wikipedia.org/wiki/HTTP_ETag。 Spring 3.0還專門為此提供了一個org.springframework.web.filter.ShallowEtagHeaderFilter(實現原理很簡單,對jsp輸出的內容md5,這樣內容有變化ETag就相應變化了),用于生成響應的ETag,因為這東東確實可以幫助減少請求和響應的交互。下面是一個ETag:
ETag: "737060cd8c284d8af7ad3082f209582d"

Location

我們在JSP中讓頁面Redirect到一個某個A頁面中,其實是讓客戶端再發一個請求到A頁面,這個需要Redirect到的A頁面的URL,其實就是通過響應報文頭的Location屬性告知客戶端的,如下的報文頭屬性,將使客戶端redirect到VEvb的首頁中:
Location: http://www.49028c.com 

Set-Cookie

服務端可以設置客戶端的Cookie,其原理就是通過這個響應報文頭屬性實現的:
Set-Cookie: UserID=JohnDoe; Max-Age=3600; Version=1  其它HTTP響應報文頭屬性 更多其它的HTTP響應頭報文,參見:http://en.wikipedia.org/wiki/List_of_HTTP_header_fields

如何寫HTTP請求報文頭

在服務端可以通過HttpServletResponse的API寫響應報文頭的屬性:
 //添加一個響應報文頭屬性  void    setHeader(String name, String value)象Cookie,Location這些響應都是有福之人,HttpServletResponse為它們都提供了VIP版的API:
    //添加Cookie報文頭屬性      void addCookie(Cookie cookie)             //不但會設置Location的響應報文頭,還會生成303的狀態碼呢,兩者天仙配呢      void    sendRedirect(String location)   


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美日韩国产精品一区二区不卡中文| 日产精品99久久久久久| 亚洲国产日韩欧美在线图片| 精品动漫一区二区三区| 国产精品激情av在线播放| 欧美成人精品激情在线观看| 日韩av综合网站| 欧美诱惑福利视频| 色噜噜亚洲精品中文字幕| 另类图片亚洲另类| 国产成人综合精品在线| 黑人极品videos精品欧美裸| 欧美日韩美女视频| 亚洲人成网在线播放| 国产精品高清免费在线观看| 九九精品在线播放| 最新国产精品拍自在线播放| 97在线视频一区| 国产一区二区三区在线看| 高清在线视频日韩欧美| 欧美中文在线字幕| 久久久午夜视频| 国产主播欧美精品| 精品久久久在线观看| 欧美国产日本在线| 日本久久中文字幕| **欧美日韩vr在线| 欧美丰满片xxx777| 午夜精品一区二区三区视频免费看| 中文字幕亚洲欧美日韩高清| 亚洲精品在线不卡| 精品久久久久久久久久| 久久久精品影院| 国产aaa精品| 一本一本久久a久久精品综合小说| 欧美一区亚洲一区| 性欧美长视频免费观看不卡| 亚洲另类激情图| 日韩国产中文字幕| 国产在线精品播放| 久久久久久91香蕉国产| 欧美亚洲第一区| 欧美性色视频在线| 国产精品日韩在线观看| 国产免费久久av| 国产欧美日韩精品丝袜高跟鞋| 欧美老少配视频| 精品国产一区二区三区久久狼黑人| 日本亚洲欧洲色α| 欧美自拍大量在线观看| 中文字幕成人在线| 91久久精品国产91久久性色| 欧美丰满片xxx777| 欧美日韩在线视频一区二区| 国产精品国产三级国产aⅴ浪潮| 亚洲国产精品资源| 欧美日韩中文在线观看| 欧美一区二粉嫩精品国产一线天| 国产精品99久久99久久久二8| 国产精品成人品| 国产精品高潮呻吟久久av无限| 国产精品激情av电影在线观看| 国产精品∨欧美精品v日韩精品| 亚洲高清免费观看高清完整版| 亚洲在线观看视频网站| 久久免费视频在线| 亚洲韩国欧洲国产日产av| 欧美激情精品久久久久久黑人| 国产精品久久久久999| 成人激情视频网| 国产精品一区二区三区在线播放| 久久久国产视频91| 国产69久久精品成人| 欧美wwwxxxx| 精品动漫一区二区三区| 亚洲国产天堂久久国产91| 高清视频欧美一级| 欧美又大又硬又粗bbbbb| 在线国产精品播放| 中文字幕日本欧美| 久久99国产精品久久久久久久久| 亚洲欧美自拍一区| 欧美久久久精品| 亚洲人成网站999久久久综合| 国产色综合天天综合网| 国精产品一区一区三区有限在线| 欧美在线激情网| 日韩欧美一区二区三区| 色偷偷偷亚洲综合网另类| 91欧美视频网站| 国产精品久久久久久av下载红粉| 成人性生交大片免费看视频直播| 欧美成人一区二区三区电影| 尤物yw午夜国产精品视频| 久久精品在线视频| 久久影视电视剧免费网站| 日本成人精品在线| 国产视频在线一区二区| 国产精品三级在线| 久久网福利资源网站| 国产精品久久久久久婷婷天堂| 久久五月情影视| 日韩av在线一区二区| 欧美国产第二页| 国产suv精品一区二区三区88区| 欧美激情极品视频| 欧美精品一区三区| 国内外成人免费激情在线视频网站| 欧美视频在线看| 国产一区视频在线播放| 欧美最近摘花xxxx摘花| 日韩经典第一页| 久久久久久久久国产精品| 2019中文字幕在线观看| 国产99久久精品一区二区| 欧美色videos| 日韩极品精品视频免费观看| 日韩精品极品毛片系列视频| 亚洲免费伊人电影在线观看av| 国产一区二区在线免费| 91精品国产免费久久久久久| 欧美大片欧美激情性色a∨久久| 午夜精品美女自拍福到在线| 久久香蕉频线观| 日韩欧美极品在线观看| 国产91在线高潮白浆在线观看| 欧美成人久久久| 欧美日本国产在线| 国产精品影片在线观看| 久久精品国产亚洲| 国产成人亚洲综合| 亚洲自拍偷拍区| 日本国产精品视频| 亚洲成人在线网| 国产精品高精视频免费| 91在线高清免费观看| 欧美日韩美女在线| 91国内免费在线视频| 久久久久久久爱| 中文字幕国内精品| 国产欧美一区二区三区视频| 色七七影院综合| 亚洲欧美精品在线| 成人欧美一区二区三区在线| 久久中文字幕视频| 4444欧美成人kkkk| 另类色图亚洲色图| 欧美成人免费一级人片100| 51久久精品夜色国产麻豆| 九九视频这里只有精品| 欧美国产中文字幕| 91人成网站www| 国产精品视频久久久| 日本精品久久久久影院| 欧美猛交ⅹxxx乱大交视频| 日本免费一区二区三区视频观看| 色伦专区97中文字幕| 欧美人成在线视频| 日韩在线视频网站| 亚洲xxxx妇黄裸体| 亚洲欧美日韩一区二区在线| 国产精品wwwwww| 国产亚洲精品日韩| 久久精品国产清自在天天线|