djxchen

            BlogJava :: 首頁 :: 聯(lián)系 :: 聚合  :: 管理
            4 Posts :: 3 Stories :: 3 Comments :: 0 Trackbacks

          1
          表單提交中Get和Post方式的區(qū)別有5點

            1. get是從服務器上獲取數(shù)據(jù),post是向服務器傳送數(shù)據(jù)。
            2. get是把參數(shù)數(shù)據(jù)隊列加到提交表單的ACTION屬性所指的URL中,值和表單內(nèi)各個字段一一對應,在URL中可以看到。post是通過HTTP post機制,將表單內(nèi)各個字段與其內(nèi)容放置在HTML HEADER內(nèi)一起傳送到ACTION屬性所指的URL地址。用戶看不到這個過程。
            3. 對于get方式,服務器端用Request.QueryString獲取變量的值,對于post方式,服務器端用Request.Form獲取提交的數(shù)據(jù)。
            4. get傳送的數(shù)據(jù)量較小,不能大于2KB。post傳送的數(shù)據(jù)量較大,一般被默認為不受限制。但理論上,IIS4中最大量為80KB,IIS5中為100KB。
            5. get安全性非常低,post安全性較高。

           
           

          HTTP請求:GET與POST方法的區(qū)別

          HTTP 定義了與服務器交互的不同方法,最基本的方法是 GET 和 POST。事實上 GET 適用于多數(shù)請求,而保留 POST 僅用于更新站點。根據(jù) HTTP 規(guī)范,GET 用于信息獲取,而且應該是 安全的和冪等的。所謂安全的意味著該操作用于獲取信息而非修改信息。換句話說,GET 請求一般不應產(chǎn)生副作用。冪等的意味著對同一 URL 的多個請求應該返回同樣的結果。完整的定義并不像看起來那樣嚴格。從根本上講,其目標是當用戶打開一個鏈接時,她可以確信從自身的角度來看沒有改變資源。比如,新聞站點的頭版不斷更新。雖然第二次請求會返回不同的一批新聞,該操作仍然被認為是安全的和冪等的,因為它總是返回當前的新聞。反之亦然。POST 請求就不那么輕松了。POST 表示可能改變服務器上的資源的請求。仍然以新聞站點為例,讀者對文章的注解應該通過 POST 請求實現(xiàn),因為在注解提交之后站點已經(jīng)不同了(比方說文章下面出現(xiàn)一條注解);
          在FORM提交的時候,如果不指定Method,則默認為GET請求,F(xiàn)orm中提交的數(shù)據(jù)將會附加在url之后,以?分開與url分開。字母數(shù)字字符原樣發(fā)送,但空格轉(zhuǎn)換為“+“號,其它符號轉(zhuǎn)換為%XX,其中XX為該符號以16進制表示的ASCII(或ISO Latin-1)值。GET請求請?zhí)峤坏臄?shù)據(jù)放置在HTTP請求協(xié)議頭中,而POST提交的數(shù)據(jù)則放在實體數(shù)據(jù)中;
          GET方式提交的數(shù)據(jù)最多只能有1024字節(jié),而POST則沒有此限制。
           
           
           
           
          在表單里使用”post”和”get”有什么區(qū)別
           
          在Form里面,可以使用post也可以使用get。它們都是method的合法取值。但是,post和get方法在使用上至少有兩點不同:
          1、Get方法通過URL請求來傳遞用戶的輸入。Post方法通過另外的形式。
          2、Get方式的提交你需要用Request.QueryString來取得變量的值,而Post方式提交時,你必須通過Request.Form來訪問提交的內(nèi)容。

          仔細研究下面的代碼。你可以運行之來感受一下:

          代碼
          <!--兩個Form只有Method屬性不同-->
          <FORM ACTION=“getpost.asp” METHOD=“get”>
          <INPUT TYPE=“text” NAME=“Text” VALUE=“Hello World”></INPUT>
          <INPUT TYPE=“submit” VALUE=“Method=Get”></INPUT>
          </FORM>
          <BR>
          <FORM ACTION=“getpost.asp” METHOD=“post”>
          <INPUT TYPE=“text” NAME=“Text” VALUE=“Hello World”></INPUT>
          <INPUT TYPE=“submit” VALUE=“Method=Post”></INPUT>
          </FORM>

          <BR>
          <BR>

          <% If Request.QueryString(“Text”) <> ““ Then %>
          通過get方法傳遞來的字符串是: “<B><%= Request.QueryString(“Text”) %></B>“<BR>
          <% End If %>

          <% If Request.Form(“Text”) <> ““ Then %>
          通過Post方法傳遞來的字符串是: “<B><%= Request.Form(“Text”) %></B>“<BR>
          <% End If %>

          說明
          把上面的代碼保存為getpost.asp,然后運行,首先測試post方法,這時候,瀏覽器的url并沒有什么變化,返回的結果是:
          通過Post方法傳遞來的字符串是: "Hello World"
          然后測試用get方法提交,請注意,瀏覽器的url變成了:
          http://localhost/general/form/getpost.asp?Text=Hello+World
          而返回的結果是:
          通過get方法傳遞來的字符串是: "Hello World"
          最后再通過post方法提交,瀏覽器的url還是:
          http://localhost/general/form/getpost.asp?Text=Hello+World
          而返回的結果變成:
          通過get方法傳遞來的字符串是: "Hello World"
          通過Post方法傳遞來的字符串是: "Hello World"

          提示
          通過get方法提交數(shù)據(jù),可能會帶來安全性的問題。比如一個登陸頁面。當通過get方法提交數(shù)據(jù)時,用戶名和密碼將出現(xiàn)在URL上。如果:
          1、 登陸頁面可以被瀏覽器緩存;
          2、 其他人可以訪問客戶的這臺機器。
          那么,別人即可以從瀏覽器的歷史記錄中,讀取到此客戶的賬號和密碼。所以,在某些情況下,get方法會帶來嚴重的安全性問題。
          建議
          在Form中,建議使用post方法。

          posted on 2008-10-11 21:56 于元 閱讀(374) 評論(0)  編輯  收藏

          只有注冊用戶登錄后才能發(fā)表評論。


          網(wǎng)站導航:
           
          主站蜘蛛池模板: 湖南省| 吐鲁番市| 大同市| 海淀区| 乌审旗| 泰宁县| 龙门县| 淳化县| 辉南县| 金华市| 遂平县| 衡山县| 汉源县| 措美县| 高雄县| 宝鸡市| 昌宁县| 江陵县| 资中县| 青州市| 黎川县| 镶黄旗| 伊宁县| 施甸县| 监利县| 阿坝| 红安县| 横峰县| 昭苏县| 福建省| 平凉市| 溆浦县| 延安市| 安义县| 金昌市| 泊头市| 北宁市| 渝北区| 措勤县| 哈巴河县| 木里|