上課筆記html
C/S模式 client-------server 基於TCP協議 UDP協議 socket是基於TCP協議和UDP協議的的封裝 web服務:瀏覽器基於URL訪問一些資源,瀏覽器接收server發來的字符串 標準的C/S模式-------->B/S模式 http協議基於TCP協議傳送的 http特色:3.默認都是80端口 1.請求協議(瀏覽器---》server端)和響應協議 (1)請求首行 GET --->a=1&b=2 http://www.cnblogs.com/yuanchenqi/articles/6000358.html?a=1&b=2 (2)請求頭信息 keep-alive:長鏈接 3000ms Accept: */*能接收全部的數據類型 Accept: text/html q=0.8 權重 referer 引用, 統計哪些訪問是來自百度的 referer 盜鏈與反盜鏈 cookie能夠理解成一個字典(多組鍵值對)或者一個容器,http是無狀態的,須要用cookie保存,由server端返回給客戶端的 session能夠存在redis裏,sessionid是一個身份信息 Django時,會作一個網站,會用到cookie 2.無狀態 3.空行 4.請求體(請求數據,數據沒有限制)------->get沒有請求體,放在URL裏。放在地址欄裏,是get請求 post請求安全性更高的 get----》URL post---》請求體 二 響應協議(server---->瀏覽器) content-type ---->對應accept WSGI--->django默認的服務器 Apache和Nginx 4開頭:客戶端出問題 5開頭:服務端出問題 302:重定向 一個連接轉向另一個連接 請求協議,響應協議
C/S模式 client-------server 基於TCP協議 UDP協議 socket是基於TCP協議和UDP協議的的封裝 web服務:瀏覽器基於URL訪問一些資源,瀏覽器接收server發來的字符串 標準的C/S模式-------->B/S模式 http協議基於TCP協議傳送的 http特色:3.默認都是80端口 1.請求協議(瀏覽器---》server端)和響應協議 (1)請求首行 GET --->a=1&b=2 http://www.cnblogs.com/yuanchenqi/articles/6000358.html?a=1&b=2 (2)請求頭信息 keep-alive:長鏈接 3000ms Accept: */*能接收全部的數據類型 Accept: text/html q=0.8 權重 referer 引用, 統計哪些訪問是來自百度的 referer 盜鏈與反盜鏈 cookie能夠理解成一個字典(多組鍵值對)或者一個容器,http是無狀態的,須要用cookie保存,由server端返回給客戶端的 session能夠存在redis裏,sessionid是一個身份信息 Django時,會作一個網站,會用到cookie 2.無狀態 3.空行 4.請求體(請求數據,數據沒有限制)------->get沒有請求體,放在URL裏。放在地址欄裏,是get請求 post請求安全性更高的 get----》URL post---》請求體 二 響應協議(server---->瀏覽器) content-type ---->對應accept WSGI--->django默認的服務器 Apache和Nginx 4開頭:客戶端出問題 5開頭:服務端出問題 302:重定向 一個連接轉向另一個連接 請求協議,響應協議
HTTP(hypertext tansport protocol),即超文本傳輸協議。這個協議詳細規定了瀏覽器和WWW服務器之間互相通訊的規則。web
HTTP就是一個通訊規則,通訊規則規定了客戶端發送給服務器的內容格式,也規定了服務器發送給客戶端的內容格式。其實咱們要學習的就是這個兩個格式!客戶端發送給服務器的格式叫「請求協議」;服務器發送給客戶端的格式叫「響應協議」。redis
特色:django
HTTP叫超文本傳輸協議,基於請求/響應模式的!瀏覽器
HTTP是無狀態協議。緩存
URL是統一資源定位符,就是一個網址:協議名://域名:端口/路徑,例如:http://www.baidu.com:80:/index.html安全
請求協議的格式以下:服務器
請求協議的格式以下:cookie
請求首行; // 請求方式 請求路徑 協議和版本,例如:GET /index.html HTTP/1.1 請求頭信息;// 請求頭名稱:請求頭內容,即爲key:value格式,例如:Host:localhost 空行; // 用來與請求體分隔開 請求體。 // GET沒有請求體,只有POST有請求體。
瀏覽器發送給服務器的內容就這個格式的,若是不是這個格式服務器將沒法解讀!在HTTP協議中,請求有不少請求方法,其中最爲經常使用的就是GET和POST。不一樣的請求方法之間的區別,後面會一點一點的介紹。網絡
HTTP默認的請求方法就是GET
*沒有請求體
*數據在1K以內!
*GET請求數據會暴露在瀏覽器的地址欄中
GET請求經常使用的操做:
1.在瀏覽器的地址欄中直接給出URL,那麼就必定是GET請求
2.點擊頁面上的超連接也必定是GET請求
3.提交表單時,表單默認使用GET請求,但能夠設置爲POST
Accept:text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8 Accept-Encoding:gzip, deflate, sdch Accept-Language:zh-CN,zh;q=0.8 Cache-Control:no-cache Connection:keep-alive Cookie:csrftoken=z5H43ZwARx7AIJ82OEizBOWbsAQA2LPk Host:127.0.0.1:8090 Pragma:no-cache Upgrade-Insecure-Requests:1 User-Agent:Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/53.0.2785.89 Safari/537.36 Name login/ 1 requests ❘ 737 B transferred ❘ Finish: 5 ms ❘ DOMContentLoaded: 14 ms ❘ Load: 14 ms
注意:
HTTP無狀態:無狀態是指協議對於事物處理沒有記憶能力,服務器不知道客戶端是什麼狀態。從另外一方面講,打開一個服務器上的網頁和你以前打開這個服務器上的網頁之間沒有任何聯繫 若是你要實現一個購物車,須要藉助於Cookie或Session或服務器端API(如NSAPI and ISAPI)記錄這些信息,請求服務器結算頁面時同時將這些信息提交到服務器 當你登陸到一個網站時,你的登陸狀態也是由Cookie或Session來「記憶」的,由於服務器並不知道你是否登陸 優勢:服務器不用爲每一個客戶端鏈接分配內存來記憶大量狀態,也不用在客戶端失去鏈接時去清理內存,以更高效地去處理WEB業務 缺點:客戶端的每次請求都須要攜帶相應參數,服務器須要處理這些參數 容易犯的誤區: 1、HTTP是一個無狀態的面向鏈接的協議,無狀態不表明HTTP不能保持TCP鏈接,更不能表明HTTP使用的是UDP協議(無鏈接) 二、從HTTP/1.1起,默認都開啓了Keep-Alive,保持鏈接特性,簡單地說,當一個網頁打開完成後,客戶端和服務器之間用於傳輸 HTTP數據的TCP鏈接不會關閉,若是客戶端再次訪問這個服務器上的網頁,會繼續使用這一條已經創建的鏈接 三、Keep-Alive不會永久保持鏈接,它有一個保持時間,能夠在不一樣的服務器軟件(如Apache)中設定這個時間
(1). 數據不會出如今地址欄中
(2). 數據的大小沒有上限
(3). 有請求體
(4). 請求體中若是存在中文,會使用URL編碼!
username=%E5%BC%A0%E4%B8%89&password=123
複製代碼 咱們都知道Http協議中參數的傳輸是"key=value"這種簡直對形式的,若是要傳多個參數就須要用「&」符號對鍵值對進行分割。如"?name1=value1&name2=value2",這樣在服務端在收到這種字符串的時候,會用「&」分割出每個參數,而後再用「=」來分割出參數值。 針對「name1=value1&name2=value2」咱們來講一下客戶端到服務端的概念上解析過程: 上述字符串在計算機中用ASCII嗎表示爲: 6E616D6531 3D 76616C756531 26 6E616D6532 3D 76616C756532。 6E616D6531:name1 3D:= 76616C756531:value1 26:& 6E616D6532:name2 3D:= 76616C756532:value2 服務端在接收到該數據後就能夠遍歷該字節流,首先一個字節一個字節的吃,當吃到3D這字節後,服務端就知道前面吃得字節表示一個key,再想後吃,若是遇到26,說明從剛纔吃的3D到26子節之間的是上一個key的value,以此類推就能夠解析出客戶端傳過來的參數。 如今有這樣一個問題,若是個人蔘數值中就包含=或&這種特殊字符的時候該怎麼辦。 好比說「name1=value1」,其中value1的值是「va&lu=e1」字符串,那麼實際在傳輸過程當中就會變成這樣「name1=va&lu=e1」。咱們的本意是就只有一個鍵值對,可是服務端會解析成兩個鍵值對,這樣就產生了奇異。 如何解決上述問題帶來的歧義呢?解決的辦法就是對參數進行URL編碼 URL編碼只是簡單的在特殊字符的各個字節前加上%,例如,咱們對上述會產生奇異的字符進行URL編碼後結果:「name1=va%26lu%3D」,這樣服務端會把緊跟在「%」後的字節當成普通的字節,就是不會把它當成各個參數或鍵值對的分隔符。
使用表單能夠發POST請求,但表單默認是GET
<form action="" method="post"> 關鍵字:<input type="text" name="keyword"/> <input type="submit" value="提交"/> </form>
輸入yuan後點擊提交,查看請求內容以下:
Request Headers Accept:text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8 Accept-Encoding:gzip, deflate Accept-Language:zh-CN,zh;q=0.8 Cache-Control:no-cache Connection:keep-alive Content-Length:13 Content-Type:application/x-www-form-urlencoded Cookie:csrftoken=z5H43ZwARx7AIJ82OEizBOWbsAQA2LPk Host:127.0.0.1:8090 Origin:http://127.0.0.1:8090 Pragma:no-cache Referer:http://127.0.0.1:8090/login/ Upgrade-Insecure-Requests:1 User-Agent:Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/53.0.2785.89 Safari/537.36 Form Data username:yuan
POST請求是能夠有體的,而GET請求不能有請求體。
Referer請求頭是比較有用的一個請求頭,它能夠用來作統計工做,也能夠用來作防盜鏈。
統計工做:我公司網站在百度上作了廣告,但不知道在百度上作廣告對咱們網站的訪問量是否有影響,那麼能夠對每一個請求中的Referer進行分析,若是Referer爲百度的不少,那麼說明用戶都是經過百度找到咱們公司網站的。
防盜鏈:我公司網站上有一個下載連接,而其餘網站盜鏈了這個地址,例如在我網站上的index.html頁面中有一個連接,點擊便可下載JDK7.0,但有某我的的微博中盜鏈了這個資源,它也有一個連接指向咱們網站的JDK7.0,也就是說登陸它的微博,點擊連接就能夠從我網站上下載JDK7.0,這致使咱們網站的廣告沒有看,但下載的倒是我網站的資源。這時可使用Referer進行防盜鏈,在資源被下載以前,咱們對Referer進行判斷,若是請求來自本網站,那麼容許下載,若是非本網站,先跳轉到本網站看廣告,而後再容許下載。
響應協議的格式以下:
響應首行;
響應頭信息;
空行;
響應體。
響應內容是由服務器發送給瀏覽器的內容,瀏覽器會根據響應內容來顯示。遇到<img src=''>會開一個新的線程加載,因此有時圖片多的話,內容會先顯示出來,而後圖片才一張張加載出來。
Request URL:http://127.0.0.1:8090/login/ Request Method:GET Status Code:200 OK Remote Address:127.0.0.1:8090 Response Headers view source Content-Type:text/html; charset=utf-8 Date:Wed, 26 Oct 2016 06:48:50 GMT Server:WSGIServer/0.2 CPython/3.5.2 X-Frame-Options:SAMEORIGIN <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> <form action="/login/" method="post"> 用戶名:<input type="text" name="username"/> <input type="submit" value="提交"/> </form> </body> </html>
響應頭對瀏覽器來講很重要,它說明了響應的真正含義。例如200表示響應成功了,302表示重定向,這說明瀏覽器須要再發一個新的請求。
當用戶第一次請求index.html時,服務器會添加一個名爲Last-Modified響應頭,這個頭說明了 index.html的最後修改時間,瀏覽器會把index.html內容,以及最後響應時間緩存下來。當用戶第 二次請求index.html時,在請求中包含一個名爲If-Modified-Since請求頭,它的值就是第一次請 求時服務器經過Last-Modified響應頭髮送給瀏覽器的值,即index.html最後的修改時間, If-Modified-Since請求頭就是在告訴服務器,我這裏瀏覽器緩存的index.html最後修改時間是這個, 您看看如今的index.html最後修改時間是否是這個,若是仍是,那麼您就不用再響應這個index.html 內容了,我會把緩存的內容直接顯示出來。而服務器端會獲取If-Modified-Since值,與index.html 的當前最後修改時間比對,若是相同,服務器會發響應碼304,表示index.html與瀏覽器上次緩存的相 同,無需再次發送,瀏覽器能夠顯示本身的緩存頁面,若是比對不一樣,那麼說明index.html已經作了修 改,服務器會響應200。
告訴瀏覽器不要緩存的響應頭:
自動刷新響應頭,瀏覽器會在3秒以後請求http://www.baidu.com:
在HTMl頁面中可使用<meta http-equiv="" content="">來指定響應頭,例如在index.html頁面中給出<meta http-equiv="Refresh" content="3;url=http://www.baidu.com">,表示瀏覽器只會顯示index.html頁面3秒,而後自動跳轉到http://www.baidu.com.