HTTP協議簡介
即超文本傳輸協議(HTTP,HyperText Transfer Protocol)是互聯網上應用最為廣泛的一種網絡協議,所有的WWW文件都必須遵守這個標准。從網絡參考模型來看,它是屬於應用層。它規定了計算機通信網絡中兩台計算機之間進行通信所必須共同遵守的規定或規則,它允許將超文本標記語言(HTML)文檔從Web服務器傳送到客戶端的瀏覽器。簡單的來說,它就是基於應用層一個規范一個標准!通訊雙發都需要遵守這一准則,這就是http協議!
HTTP特點
簡單快速:客戶端向服務器發起請求時,只需要傳請求方法和路徑。請求方法包括get、post、put、delete、head,每種方法規定了客戶端與服務器聯系的類型。由於http協議簡單,使得http服務器的程序規模小,因而通信速度很快。
靈活:http允許傳輸任意類型的數據對象,正在傳輸的類型由Content-Type加以標記。
無連接:無連接的含義是限制每次連接只處理一個請求。服務器處理完客戶的請求,並收到客戶的應答后,即斷開連接。采用這種方式可以節省傳輸時間。
無狀態:http協議是無狀態協議,無狀態是指協議對於事務處理沒有記憶能力。缺少狀態意味着如果后續處理需要前面的信息,則它必須重傳,這樣可能導致每次連接傳送的數據量增大。另一方面,在服務器不需要先前信息時它的應答就較快。
支持C/S(Client/Server)模式。
URI和URL
簡介
http使用統一資源標識符(Uniform Resource Identifiers, URI)來傳輸數據和建立連接。URL是一種特殊類型的URI,包含了用於查找某個資源的足夠的信息URL,全稱是UniformResourceLocator,中文叫統一資源定位符,是互聯網上用來標識某一處資源的地址。
URI和URL的區別
URI,是uniform resource identifier,統一資源標識符,用來唯一的標識一個資源。URL是uniform resource locator,統一資源定位器,它是一種具體的URI,即URL可以用來標識一個資源,而且還指明了如何locate這個資源。URI,是uniform resource identifier,統一資源標識符,用來唯一的標識一個資源。URL是uniform resource locator,統一資源定位器,它是一種具體的URI,即URL可以用來標識一個資源,而且還指明了如何locate這個資源。
狀態碼
狀態代碼有三位數字組成,第一個數字定義了響應的類別,共分五種類別:
1xx:指示信息 - 表示請求已接收,繼續處理。
2xx:成功 - 表示請求已被成功接收、理解、接受。
3xx:重定向 - 要完成請求必須進行更進一步的操作。
4xx:客戶端錯誤 - 請求有語法錯誤或請求無法實現。
5xx:服務器端錯誤 - 服務器未能實現合法的請求。
常見狀態碼:
其他狀態碼
100——客戶必須繼續發出請求
101——客戶要求服務器根據請求轉換HTTP協議版本
200——交易成功
201——提示知道新文件的URL
202——接受和處理、但處理未完成
203——返回信息不確定或不完整
204——請求收到,但返回信息為空
205——服務器完成了請求,用戶代理必須復位當前已經瀏覽過的文件
206——服務器已經完成了部分用戶的GET請求
300——請求的資源可在多處得到
301——刪除請求數據
302——在其他地址發現了請求數據
303——建議客戶訪問其他URL或訪問方式
304——客戶端已經執行了GET,但文件未變化
305——請求的資源必須從服務器指定的地址得到
306——前一版本HTTP中使用的代碼,現行版本中不再使用
307——申明請求的資源臨時性刪除
400——錯誤請求,如語法錯誤
401——請求授權失敗
402——保留有效ChargeTo頭響應
403——請求不允許
404——沒有發現文件、查詢或URl
405——用戶在Request-Line字段定義的方法不允許
406——根據用戶發送的Accept拖,請求資源不可訪問
407——類似401,用戶必須首先在代理服務器上得到授權
408——客戶端沒有在用戶指定的時間內完成請求
409——對當前資源狀態,請求不能完成
410——服務器上不再有此資源且無進一步的參考地址
411——服務器拒絕用戶定義的Content-Length屬性請求
412——一個或多個請求頭字段在當前請求中錯誤
413——請求的資源大於服務器允許的大小
414——請求的資源URL長於服務器允許的長度
415——請求資源不支持請求項目格式
416——請求中包含Range請求頭字段,在當前請求資源范圍內沒有range指示值,請求也不包含If-Range請求頭字段
417——服務器不滿足請求Expect頭字段指定的期望值,如果是代理服務器,可能是下一級服務器不能滿足請求
500——服務器產生內部錯誤
501——服務器不支持請求的函數
502——服務器暫時不可用,有時是為了防止發生系統過載
503——服務器過載或暫停維修
504——關口過載,服務器使用另一個關口或服務來響應用戶,等待時間設定值較長
505——服務器不支持或拒絕支請求頭中指定的HTTP版本
HTTP協議請求
http請求由三部分組成,分別是:請求行、消息報頭、請求正文。
請求方法
(所有方法全為大寫)有多種,各個方法的解釋如下:
請求行
請求行以一個方法符號開頭,以空格分開,后面跟着請求的URI和協議的版本,格式如下:
Method Request-URI HTTP-Version CRLF
其中 Method表示請求方法;Request-URI是一個統一資源標識符;HTTP-Version表示請求的HTTP協議版本;CRLF表示回車和換行(除了作為結尾的CRLF外,不允許出現單獨的CR或LF字符)
GET和POST的區別
1、GET提交的數據會放在URL之后,以?分割URL和傳輸數據,參數之間以&相連,如EditPosts.aspx?name=test1&id=123456. POST方法是把提交的數據放在HTTP包的Body中.
2、GET提交的數據大小有限制(因為瀏覽器對URL的長度有限制),而POST方法提交的數據沒有限制.
3、GET方式需要使用請求的QueryString來取得變量的值,而POST方式通過請求的Form來獲取變量的值。
4、GET方式提交數據,會帶來相對不安全的問題
時間戳
版本更新,解決瀏覽器緩存
緩存:200 from memory cache 不訪問服務器,直接讀取緩存 ,從內存當中讀取
200 from disk cache 不訪問服務器,直接讀取緩存,從磁盤當中讀取
304 訪問服務器,發現數據沒有更新,服務器返回次狀態碼,然后再從緩存中讀取數據