下面定義了HTTP/1.1
的常用方法集,可以根據需求擴充套件該集。這些方法名稱區分大小寫,必須以大寫形式使用。
編號 | 方法 | 描述 |
---|---|---|
1 | GET | 它用於使用給定的URI從給定伺服器檢索資訊。使用GET的請求應僅檢索資料,並且不應對資料產生其他影響。 |
2 | HEAD | 它與GET相同,但僅傳輸狀態行和檔頭部分。 |
3 | POST | 它用於將資料傳送到伺服器。例如,使用HTML表單的客戶資訊,檔案上載等。 |
4 | PUT | 它用上傳的內容替換目標資源的所有當前表示。 |
5 | DELETE | 它刪除URI給出的目標資源的所有當前表示。 |
6 | CONNECT | 它建立到由給定URI標識的伺服器的通道。 |
7 | OPTIONS | 它描述了目標資源的通訊選項。 |
8 | TRACE | 它沿著目標資源的路徑執行訊息環回測試。 |
它通過在請求的URL部分中指定引數來從Web伺服器檢索資料。這是用於文件檢索的主要方法。以下範例使用GET方法獲取hello.html
-
GET /hello.html HTTP/1.1
User-Agent: Mozilla/4.0 (compatible; MSIE5.01; Windows NT)
Host: www.tw511.com
Accept-Language: en-us
Accept-Encoding: gzip, deflate
Connection: Keep-Alive
針對上述GET請求發出以下伺服器響應 -
HTTP/1.1 200 OK
Date: Mon, 27 Jul 2019 12:28:53 GMT
Server: Apache/2.2.14 (Win32)
Last-Modified: Wed, 22 Jul 2019 19:15:56 GMT
ETag: "34aa387-d-1568eb00"
Vary: Authorization,Accept
Accept-Ranges: bytes
Content-Length: 88
Content-Type: text/html
Connection: Closed
<html>
<body>
<h1>Hello, World!</h1>
</body>
</html>
它在功能上類似於GET,除了伺服器回復響應行和檔頭,但沒有實體主體。以下範例使用HEAD
方法獲取有關hello.html
的檔頭資訊 -
HEAD /hello.html HTTP/1.1
User-Agent: Mozilla/4.0 (compatible; MSIE5.01; Windows NT)
Host: www.tw511.com
Accept-Language: en-us
Accept-Encoding: gzip, deflate
Connection: Keep-Alive
針對上述GET請求發出以下伺服器響應 -
HTTP/1.1 200 OK
Date: Mon, 27 Jul 2019 12:28:53 GMT
Server: Apache/2.2.14 (Win32)
Last-Modified: Wed, 22 Jul 2019 19:15:56 GMT
ETag: "34aa387-d-1568eb00"
Vary: Authorization,Accept
Accept-Ranges: bytes
Content-Length: 88
Content-Type: text/html
Connection: Closed
您應該注意到了,伺服器在檔頭之後不傳送任何資料。
當您想要將某些資料傳送到伺服器時使用POST
方法。例如,檔案更新,表單資料等。下面的簡單範例使用POST方法將表單資料傳送到由process.cgi
處理的伺服器,最後返回響應 -
POST /cgi-bin/process.cgi HTTP/1.1
User-Agent: Mozilla/4.0 (compatible; MSIE5.01; Windows NT)
Host: www.tw511.com
Content-Type: text/xml; charset = utf-8
Content-Length: 88
Accept-Language: en-us
Accept-Encoding: gzip, deflate
Connection: Keep-Alive
<?xml version = "1.0" encoding = "utf-8"?>
<string xmlns = "http://kaops.com/">string</string>
伺服器端指令碼process.cgi
處理傳遞的資料並行送以下響應 -
HTTP/1.1 200 OK
Date: Mon, 27 Jul 2019 12:28:53 GMT
Server: Apache/2.2.14 (Win32)
Last-Modified: Wed, 22 Jul 2009 19:15:56 GMT
ETag: "34aa387-d-1568eb00"
Vary: Authorization,Accept
Accept-Ranges: bytes
Content-Length: 88
Content-Type: text/html
Connection: Closed
<html>
<body>
<h1>Request Processed Successfully</h1>
</body>
</html>
PUT
方法用於請求伺服器將包含的實體主體儲存在給定URL指定的位置。以下範例請求伺服器將給定的實體儲存在伺服器根目錄的hello.html
中 -
PUT /hello.html HTTP/1.1
User-Agent: Mozilla/4.0 (compatible; MSIE5.01; Windows NT)
Host: www.tw511.com
Accept-Language: en-us
Connection: Keep-Alive
Content-type: text/html
Content-Length: 182
<html>
<body>
<h1>Hello, World!</h1>
</body>
</html>
伺服器將給定的實體主體儲存在hello.html
檔案中,並將以下響應傳送回用戶端 -
HTTP/1.1 201 Created
Date: Mon, 27 Jul 2019 12:28:53 GMT
Server: Apache/2.2.14 (Win32)
Content-type: text/html
Content-length: 30
Connection: Closed
<html>
<body>
<h1>The file was created.</h1>
</body>
</html>
DELETE
方法用於請求伺服器刪除給定URL指定的位置的檔案。以下範例請求伺服器刪除伺服器根目錄下的給定檔案hello.html
-
DELETE /hello.html HTTP/1.1
User-Agent: Mozilla/4.0 (compatible; MSIE5.01; Windows NT)
Host: www.tw511.com
Accept-Language: en-us
Connection: Keep-Alive
伺服器刪除指定的檔案hello.html
並將以下響應傳送回用戶端 -
HTTP/1.1 200 OK
Date: Mon, 27 Jul 2019 12:28:53 GMT
Server: Apache/2.2.14 (Win32)
Content-type: text/html
Content-length: 30
Connection: Closed
<html>
<body>
<h1>URL deleted.</h1>
</body>
</html>
用戶端使用它通過HTTP建立到Web伺服器的網路連線。以下範例請求與主機tw511.com
上執行的Web伺服器建立連線 -
CONNECT www.tw511.com HTTP/1.1
User-Agent: Mozilla/4.0 (compatible; MSIE5.01; Windows NT)
與伺服器建立連線,並將以下響應傳送回用戶端 -
HTTP/1.1 200 Connection established
Date: Mon, 27 Jul 2019 12:28:53 GMT
Server: Apache/2.2.14 (Win32)
用戶端使用它來查詢Web伺服器支援的HTTP方法和其他選項。用戶端可以指定OPTIONS
方法的URL,也可以指定星號(*
)來參照整個伺服器。以下範例請求在tw511.com
上執行的Web伺服器支援的方法列表 -
OPTIONS * HTTP/1.1
User-Agent: Mozilla/4.0 (compatible; MSIE5.01; Windows NT)
伺服器根據伺服器的當前組態傳送響應的資訊,例如 -
HTTP/1.1 200 OK
Date: Mon, 27 Jul 2019 12:28:53 GMT
Server: Apache/2.2.14 (Win32)
Allow: GET,HEAD,POST,OPTIONS,TRACE
Content-Type: httpd/unix-directory
它用於將HTTP請求的內容回送給請求者,請求者可以在開發時用於偵錯目的。以下範例顯示了TRACE
方法的用法 -
TRACE / HTTP/1.1
Host: www.tw511.com
User-Agent: Mozilla/4.0 (compatible; MSIE5.01; Windows NT)
伺服器將傳送以下訊息以響應上述請求 -
HTTP/1.1 200 OK
Date: Mon, 27 Jul 2019 12:28:53 GMT
Server: Apache/2.2.14 (Win32)
Connection: close
Content-Type: message/http
Content-Length: 39
TRACE / HTTP/1.1
Host: www.tw511.com
User-Agent: Mozilla/4.0 (compatible; MSIE5.01; Windows NT)