HTTP
- 概念: Hyper Text Thansfer Portocol 超文本協議
-
傳輸協議 : 定義了客戶端和服務端通信時,發生數據的格式
-
特點:
- 基本TCP/IP的高級協議
- ,默認端口: 80
- 基於請求/響應模型的: 一次請求對應一次響應
- 無狀態: 每次請求之間相互獨立,不能交換互數據
-
歷史版本:
- 1.0: 每一次請求響應都會建立新的連接
- 1.1: 複用連接 (速度快)
-
- 請求消息: 客戶端發送給服務器端的數據
字符串格式
POST /login.html HTTP/1.1
Host: localhost
User-Agent: Mozilla/5.0 (Windows NT 6.1; Win64; x64; rv:60.0) Gecko/20100101 Firefox/60.0
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Language: zh-CN,zh;q=0.8,zh-TW;q=0.7,zh-HK;q=0.5,en-US;q=0.3,en;q=0.2
Accept-Encoding: gzip, deflate
Referer: http://localhost/login.html
Connection: keep-alive
Upgrade-Insecure-Requests: 1
username=zhangsan
1. 請求行
請求方式 請求url 請求協議/版本
GET(或POST) /login.html HTTP/1.1
* 請求方式:
* HTTP協議有七種請求方式,常用的有2種
* GET:
1. 請求參數在請求行中,在url後
2. 請求的url長度有限制
3. 不太安全 (數據直接在地址欄顯示)
* POST:
1. 請求參數在請求體中
2. 請求的url沒有限制的
3. 相對安全 (數據在按F12哪裏才能看到)
2. 請求頭: 客戶端瀏覽器告訴服務器一些信息
請求頭名稱: 請求值
* 常見的請求頭:
1. User-Agent: 瀏覽器告訴服務器,我訪問你使用的瀏覽器版本信息
* 可以在服務端獲取該頭的信息,解決瀏覽器
2. Referer:
* 告訴服務器,我(當前請求)從哪裏來?
* 作用:
1. 防盜鏈:
2. 統計工作:
3. 請求空行
空行, 就是用於分割POST請求的請求頭和請求體的
4. 請求體(正文)
* 封裝POST請求消息的請求參數的
- 響應消息: 服務器端發送給客戶端的數據
* 響應的字符串格式
HTTP/1.1 200 OK
Content-Type: text/html;charset=UTF-8
Content-Length: 101
Date: Wed, 06 Jun 2018 07:08:42 GMT
<html>
<head>
<title>$Title$</title>
</head>
<body>
hello , response
</body>
</html>
1. 響應行
1. 組成: 協議/版本 響應狀態碼 狀態碼描述
2. 響應狀態碼: 服務器告訴客戶端瀏覽器本次請求和響應的一個狀態
* 分類:
1. 1xx: 服務器就收客戶端消息,但沒有接收完成,等待一段時間後,發送1xx多狀態碼
2. 2xx: 成功. 代表: 200
3. 3xx: 重定向. 代表: 302(重定向), 304(訪問緩存)
4. 4xx: 客戶端錯誤.
* 代表:
* 404(路徑沒有對應的資源)
* 405: 請求方式沒有對應的doXxx方法
5. 5xx: 服務器端錯誤. 代表: 500(服務器內部出現異常)
2. 響應頭
1. 格式: 頭名稱: 值
2. 常見響應頭:
1. Content-Type: 服務器告訴客戶端本次響應數據格式以及編碼格式
2. Content-disposition: 服務器告訴客戶端以什麼格式打開響應體數據
* 值:
* in-line 默認值,在當前頁面內打開
* attchment: filename = xxx : 以附件形式打開響應體. 文件下載
3. 響應空行
4. 響應體: 傳輸的數據