4 回答

TA貢獻1839條經(jīng)驗 獲得超15個贊
其中,HEAD請求在客戶程序和服務器之間進行交流,而不會返回具體的文檔。當使用GET和POST方法時,服務器最后都將結果文檔返回給客戶程序,瀏覽器將 刷新顯示。而HEAD請求則不同,它僅僅交流一些內部數(shù)據(jù),這些數(shù)據(jù)不會影響瀏覽的過程。因此HEAD方法通常不單獨使用,而是和其他的請求方法一起起到 輔助作用。一些搜尋引擎使用的自動搜索機器人使用這個方法來獲得網(wǎng)頁的標志信息,或者進行安全認證時,使用這個方法來傳遞認證信息。
除了這三種最常見的訪問方法之外,在HTTP1.1中還定義了更多的訪問方法類型,如PUT,用于將網(wǎng)頁放置到正確位置,DELETE用于刪除相關文檔 等。這些方法并不常用,因而大部分Web服務器軟件并沒有實現(xiàn)他們。然而對于特定場合他們還是非常有用的,例如使用軟件編輯網(wǎng)頁時,網(wǎng)頁編輯器可以使用這 些方法,管理不同的網(wǎng)頁。
如果服務器不支持客戶發(fā)送的請求方法,服務器將返回錯誤并立即關閉連接。

TA貢獻1784條經(jīng)驗 獲得超2個贊
最簡單的http請求是
GET / HTTP/1.0
其中GET是關鍵字
/表示請求的是跟目錄主頁
HTTP/1.0表示使用HTTP協(xié)議的1.0版本通訊
作為服務器端,這是會向服務器返回首頁的全部html代碼
至此,一個最簡單的http通訊就完成了。但是,此時網(wǎng)頁還不能正常顯示,因為服務器僅僅返回了html代碼,客戶端還必須根據(jù)html代碼中涉及的其他文件(例如css、js、圖象、flash等等)的地址獲得相應文件,才能使網(wǎng)頁正常顯示

TA貢獻1784條經(jīng)驗 獲得超9個贊
1、HTTP請求概述
在前面有一篇文章對HTTP協(xié)議有詳細的描述,這里就不再過多的做說明,只是簡單的作為這篇文章的引子。
HTTP協(xié)議又被稱為超文本傳輸協(xié)議,它的的設計目的是保證客戶機與服務器之間的通信。HTTP 的工作方式是客戶端與服務器之間的請求-應答協(xié)議。在客戶端和服務器之間進行請求-響應時,有兩個最基本的請求方式:GET 和 POST。
其中,GET請求表示從指定的資源請求數(shù)據(jù),POST請求表示向指定的資源提交要被處理的數(shù)據(jù)。
2、HTTP請求格式
在HTTP請求中,首先是請求行,注意這里的請求行一定要放在最前面;其次,是請求頭,英文表示為header;然后會空一行,緊接著就可以是請求的具體內容了,一般稱之為請求體,request-body。給出一個圖示如下:
3、GET請求與POST請求對比
GET請求與POST請求有一些異同點,主要有以下幾點問題:
(1)、GET請求和POST請求都是客戶端與服務器之間交互,請求--應答模式的協(xié)議
(2)、GET請求是通過URL直接請求數(shù)據(jù),數(shù)據(jù)信息可以在URL中直接看到,比如瀏覽器訪問;而POST請求是放在請求頭中的,我們是無法直接看到的;
(3)、GET提交有數(shù)據(jù)大小的限制,一般是不超過1024個字節(jié),而這種說法也不完全準確,HTTP協(xié)議并沒有設定URL字節(jié)長度的上限,而是瀏
覽器做了些處理,所以長度依據(jù)瀏覽器的不同有所不同;POST請求在HTTP協(xié)議中也沒有做說明,一般來說是沒有設置限制的,但是實際上瀏覽器也有默認
值??傮w來說,少量的數(shù)據(jù)使用GET,大量的數(shù)據(jù)使用POST。
(4)、GET請求因為數(shù)據(jù)參數(shù)是暴露在URL中的,所以安全性比較低,比如密碼是不能暴露的,就不能使用GET請求;POST請求中,請求參數(shù)信息是放在請求頭的,所以安全性較高,可以使用。在實際中,涉及到登錄操作的時候,盡量使用HTTPS請求,安全性更好。
下面給出一副圖示,說明一下HTTP中GET與POST請求的差異:
4、使用步驟:
在Android中使用HTTP請求,主要步驟如下:
(1)、實例化一個HttpGet(或HttpPost)對象,將請求的URL地址通過構造方法傳給HttpGet(或HttpPost)對象;
(2)、使用DefaultHttpClient類的execute方法發(fā)送GET或POST 請求,并返回HttpResponse對象;
(3)、通過HttpResponse接口的getEntity方法返回響應信息。
5、實例代碼
給出一個在實際應用中的一個POST請求的代碼片段:
[java] view plain copy print?
params = new LinkedList();
params.add(new BasicNameValuePair("param1", "Post方法"));
params.add(new BasicNameValuePair("param2", "第二個參數(shù)"));
try {
HttpPost post = new HttpPost(baseUrl);
post.setEntity(new UrlEncodedFormEntity(params, "utf-8")); //將參數(shù)填入POST Entity中
HttpResponse response = httpClient.execute(post); //執(zhí)行POST方法
resCode = response.getStatusLine().getStatusCode()); //獲取響應碼
result = EntityUtils.toString(response.getEntity(), "utf-8")); //獲取響應內容
} catch (UnsupportedEncodingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (ClientProtocolException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
6、HTTP請求狀態(tài)碼意義
HTTP請求中,主要有這樣幾個類型:1XX:表示信息提示,2XX:表示成功,3XX:表示重定向,4XX:表示客戶端請求錯誤,5XX:表示服務器錯誤。常見的幾個HTTP請求狀態(tài)碼意義如下:
200 OK: 找到了該資源,并且一切正常。
304 NOT MODIFIED: 該資源在上次請求之后沒有任何修改。這通常用于瀏覽器的緩存機制。
401 UNAUTHORIZED: 客戶端無權訪問該資源。這通常會使得瀏覽器要求用戶輸入用戶名和密碼,以登錄到服務器。
403 FORBIDDEN: 客戶端未能獲得授權。這通常是在401之后輸入了不正確的用戶名或密碼。
404 NOT FOUND: 在指定的位置不存在所申請的資源。
505 NOT SUPPORTED:服務器不支持請求中所指明的HTTP版本
- 4 回答
- 0 關注
- 955 瀏覽
添加回答
舉報