天天看點

HTTP請求方式中get和post的差別

表單送出中get和post方式的差別有5點

1.get是從伺服器上擷取資料,post是向伺服器傳送資料。

2.get是把參數資料隊列加到送出表單的ACTION屬性所指的URL中,值和表單内各個字段一一對應,在URL中可以看到。post是通過HTTPpost機制,将表單内各個字段與其内容放置在HTML HEADER内一起傳送到ACTION屬性所指的URL位址。使用者看不到這個過程。

3.對于get方式,伺服器端用Request.QueryString擷取變量的值,對于post方式,伺服器端用Request.Form擷取送出的資料。

4.get傳送的資料量較小,不能大于2KB。post傳送的資料量較大,一般被預設為不受限制。但理論上,IIS4中最大量為80KB,IIS5中為100KB。(這裡有看到其他文章介紹get和post的傳送資料大小跟各個浏覽器、作業系統以及伺服器的限制有關)

5.get安全性非常低,post安全性較高。

表單送出中get和post方式的差別有5點

1.get是從伺服器上擷取資料,post是向伺服器傳送資料。

2.get是把參數資料隊列加到送出表單的ACTION屬性所指的URL中,值和表單内各個字段一一對應,在URL中可以看到。post是通過HTTPpost機制,将表單内各個字段與其内容放置在HTML HEADER内一起傳送到ACTION屬性所指的URL位址。使用者看不到這個過程。

3.對于get方式,伺服器端用Request.QueryString擷取變量的值,對于post方式,伺服器端用Request.Form擷取送出的資料。

4.get傳送的資料量較小,不能大于2KB。post傳送的資料量較大,一般被預設為不受限制。但理論上,IIS4中最大量為80KB,IIS5中為100KB。

5.get安全性非常低,post安全性較高。

HTTP請求:get與post方法的差別

HTTP 定義了與伺服器互動的不同方法,最基本的方法是 get 和 post。事實上 get 适用于多數請求,而保留 post僅用于更新站點。根據 HTTP 規範,get 用于資訊擷取,而且應該是安全的和幂等的。所謂安全的意味着該操作用于擷取資訊而非修改資訊。換句話說,get 請求一般不應産生副作用。幂等的意味着對同一 URL的多個請求應該傳回同樣的結果。完整的定義并不像看起來那樣嚴格。從根本上講,其目标是當使用者打開一個連結時,她可以确信從自身的角度來看沒有改變資源。比如,新聞站點的頭版不斷更新。雖然第二次請求會傳回不同的一批新聞,該操作仍然被認為是安全的和幂等的,因為它總是傳回目前的新聞。反之亦然。post請求就不那麼輕松了。post 表示可能改變伺服器上的資源的請求。仍然以新聞站點為例,讀者對文章的注解應該通過 post請求實作,因為在注解送出之後站點已經不同了(比方說文章下面出現一條注解);

在FORM送出的時候,如果不指定Method,則預設為get請求,Form中送出的資料将會附加在url之後,以?分開與url分開。字母數字字元原樣發送,但空格轉換為“+“号,其它符号轉換為%XX,其中XX為該符号以16進制表示的ASCII(或ISOLatin-1)值。get請求請送出的資料放置在HTTP請求協定頭中,而post送出的資料則放在實體資料中;

以下為代碼示範:

HTTP請求方式中get和post的差別
HTTP請求方式中get和post的差別
1 <body>
 2     <form action="/tablelist/tablelist.ashx" method="get">
 3         <input type="text" name="id" value=" " />
 4         <input type="text" name="name" value=" " />
 5         <input type="submit" name="submit" value="get送出的一種方式" />
 6     </form>
 7     <form action="/tablelist/tablelist.ashx" method="post">
 8         <input type="text" name="id" value=" " />
 9         <input type="text" name="name" value=" " />
10         <input type="submit" name="submit" value="post送出的一種方式" />
11     </form>
12 </body>      
HTTP請求方式中get和post的差別

運作第一個form表單,結果如下圖

HTTP請求方式中get和post的差別

表單中的參數被送出到Action所指定的URL中,值和表單内各個字段一一對應,在URL中可以看到。空格符号被轉為了加号,送出按鈕中的中文被轉換為了%+以16進制表示的ASCII(或ISOLatin-1)值。表單送出到伺服器後,傳回了使用者在表單中指定參數所對應的結果。

運作post表單後的結果如下圖:

HTTP請求方式中get和post的差別

伺服器沒有傳回使用者表單中送出參數所對應的結果,但是表單内各個字段與其内容被放置在HTML HEADER内一起傳送到ACTION屬性所指的URL位址,使用者在位址欄看不到。

通過get方法送出資料,可能會帶來安全性的問題。比如一個登陸頁面。當通過get方法送出資料時,使用者名和密碼将出現在URL上。如果:

1、 登陸頁面可以被浏覽器緩存;

2、 其他人可以通路客戶的這台機器。那麼,别人即可以從浏覽器的曆史記錄中,讀取到此客戶的賬号和密碼。是以,在某些情況下,get方法會帶來嚴重的安全性問題。 

get與post的差別2

get:是以實體的方式得到由請求URI所指定資源的資訊,如果請求URI隻是一個資料産生過程,那麼最終要在響應實體中傳回的是處理過程的結果所指向的資源,而不是處理過程的描述。

post:用來向目的伺服器送出請求,要求它接受被附在請求後的實體,并把它當作請求隊列中請求URI所指定資源的附加新子項,post被設計成用統一的方法實作下列功能:

1:對現有資源的解釋

2:向電子公告欄、新聞討論區、郵件清單或類似讨論組發資訊。

3:送出資料塊

4:通過附加操作來擴充資料庫

從上面描述可以看出,get是向伺服器發索取資料的一種請求;而post是向伺服器送出資料的一種請求,要送出的資料位于資訊頭後面的實體中。