表單提交中Get和Post 方式的區別

   1. get是從服務器上獲取數據,post是向服務器傳送數據。
   2. get是把參數數據隊列加到提交表單的ACTION屬性所指的URL中,值和表單內各個字段一一對應,在URL中能夠看到。post是經過HTTP post機制,將表單內各個字段與其內容放置在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(或ISO Latin-1)值。GET請求請提交的數據放置在HTTP請求協議頭中,而POST 提交的數據則放在實體數據中;GET方式提交的數據最多隻能有1024字節,而POST 則沒有此限制。
經過get方法提交數據,可能會帶來安全性的問題。好比一個登錄頁面。當經過get方法提交數據時,用戶名和密碼將出如今URL上。若是:
1、 登錄頁面能夠被瀏覽器緩存;
2、 其餘人能夠訪問客戶的這臺機器。
那麼,別人便可以從瀏覽器的歷史記錄中,讀取到此客戶的帳號和密碼。因此,在某些狀況下,get方法會帶來嚴重的安全性問題。
建議在Form中,建議使用post 方法。瀏覽器

相關文章
相關標籤/搜索