<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    無線&移動互聯網技術研發

    換位思考·····
    posts - 19, comments - 53, trackbacks - 0, articles - 283
      BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

    POST && GET區別

    Posted on 2009-05-23 11:24 Gavin.lee 閱讀(408) 評論(0)  編輯  收藏 所屬分類: web 積累(前端 + 后臺)

    既然這里都叫 WEB相關了,這兩個肯定是要談的,話不多說了,下面是我以前寫的一點總結,給轉到這里。
    在說get && post前,就要引入request response。

    請求消息:request

    GET /myweb/login.do?username=brady&password=1111 HTTP/1.1

    Host: localhost

    User-Agent: Mozilla/5.0 (Windows; U; Windows NT 5.1; zh-CN; rv:1.8.1.6) Gecko/20070725 Firefox/2.0.0.6

    Accept: text/html;image/png,*/*

    Accept-Language: zh-cn

    Accept-Encoding: gzip,deflate

    Accept-Charset: gb2312

    Keep-Alive: 300

    Connection: keep-alive

    Cookie: who=brady.zh


    POST /myweb/login.do HTTP/1.1

    Host: localhost

    User-Agent: Mozilla/5.0 (Windows; U; Windows NT 5.1; zh-CN; rv:1.8.1.6) Gecko/20070725 Firefox/2.0.0.6

    Accept: text/html;image/png,*/*

    Accept-Language: zh-cn

    Accept-Encoding: gzip,deflate

    Accept-Charset: gb2312

    Keep-Alive: 300

    Connection: keep-alive

    Cookie: who=brady.zh

    Content-Type: application/x-www-form-urlencoded

    Content-Length: 28

    ?

    username=brady&password=1111


    響應信息:response

    HTTP/1.1 200 OK

    Server: Apache-Coyote/1.1

    Set-Cookie: JSESSIONID=38034AF1E97054BE745275ADC90DB5C4; Path=/myweb

    Content-Type: text/html;charset=UTF-8

    Content-Length: 189

    Date: Sun, 23 Nov 2008 14:28:04 GMT


    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">

    <html>

    <head>

    ??? <title>test</title>

    </head>


    <body>

    ??? This is my test page. <br>

    </body>

    </html>

    ?

    GET/POST 都是發送請求的方法

    從上面我們不難看出一些區別:

    GET:

    1.?????? 用于直接從SERVER端檢索信息(如文檔、圖像或數據庫請求結果)

    2.?????? 請求信息作為查詢字符串發送

    3.?????? 安全性不高

    4.?????? 發送的內容長度有限(content < 512 bit)

    POST:

    1.?????? 用戶發送敏感信息(如信用卡號)或要保存到數據庫中的信息

    2.?????? 發送長度在請求頭下空一行

    3.?????? 安全性好

    4.?????? 發送的長度不高
    ?

    csdn上看到這個文章,覺得放在這里非常合適。2009年7月10日23:13:38
    HTTP請求頭概述 (HttpServletRequest)
       HTTP客戶程序(例如瀏覽器),向服務器發送請求的時候必須指明請求類型(一般是GET或者POST)。如有必要,客戶程序還可以選擇發送其他的請求頭。大多數請求頭并不是必需的,但Content-Length除外。對于POST請求來說Content-Length必須出現。
     下面是一些最常見的請求頭

       Accept:瀏覽器可接受的MIME類型。

       Accept-Charset:瀏覽器可接受的字符集。

       Accept-Encoding:瀏覽器能夠進行解碼的數據編碼方式,比如gzip。Servlet能夠向支持gzip的瀏覽器返回經gzip編碼的HTML頁面。許多情形下這可以減少5到10倍的下載時間。

       Accept-Language:瀏覽器所希望的語言種類,當服務器能夠提供一種以上的語言版本時要用到。

       Authorization:授權信息,通常出現在對服務器發送的WWW-Authenticate頭的應答中。

       Connection:表示是否需要持久連接。如果Servlet看到這里的值為“Keep-Alive”,或者看到請求使用的是HTTP 1.1(HTTP 1.1默認進行持久連接),它就可以利用持久連接的優點,當頁面包含多個元素時(例如Applet,圖片),顯著地減少下載所需要的時間。要實現這一點,Servlet需要在應答中發送一個Content-Length頭,最簡單的實現方法是:先把內容寫入 ByteArrayOutputStream,然后在正式寫出內容之前計算它的大小。

       Content-Length:表示請求消息正文的長度。

       Cookie:這是最重要的請求頭信息之一

       From:請求發送者的email地址,由一些特殊的Web客戶程序使用,瀏覽器不會用到它。

       Host:初始URL中的主機和端口。

       If-Modified-Since:只有當所請求的內容在指定的日期之后又經過修改才返回它,否則返回304“Not Modified”應答。

       Pragma:指定“no-cache”值表示服務器必須返回一個刷新后的文檔,即使它是代理服務器而且已經有了頁面的本地拷貝。

       Referer:包含一個URL,用戶從該URL代表的頁面出發訪問當前請求的頁面。

       User-Agent:瀏覽器類型,如果Servlet返回的內容與瀏覽器類型有關則該值非常有用。

       UA-Pixels,UA-Color,UA-OS,UA-CPU:由某些版本的IE瀏覽器所發送的非標準的請求頭,表示屏幕大小、顏色深度、操作系統和CPU類型。

      有關HTTP頭完整、詳細的說明,請參見http://www.w3.org/Protocols/的HTTP規范。

    HTTP應答頭概述(HttpServletResponse)
       Web服務器的HTTP應答一般由以下幾項構成:一個狀態行,一個或多個應答頭,一個空行,內容文檔。設置HTTP應答頭往往和設置狀態行中的狀態代碼結合起來。例如,有好幾個表示“文檔位置已經改變”的狀態代碼都伴隨著一個Location頭,而401(Unauthorized)狀態代碼則必須伴隨一個WWW-Authenticate頭。

       然而,即使在沒有設置特殊含義的狀態代碼時,指定應答頭也是很有用的。應答頭可以用來完成:設置Cookie,指定修改日期,指示瀏覽器按照指定的間隔刷新頁面,聲明文檔的長度以便利用持久HTTP連接,……等等許多其他任務。

       設置應答頭最常用的方法是HttpServletResponse的setHeader,該方法有兩個參數,分別表示應答頭的名字和值。和設置狀態代碼相似,設置應答頭應該在發送任何文檔內容之前進行。

       setDateHeader方法和setIntHeadr方法專門用來設置包含日期和整數值的應答頭,前者避免了把Java時間轉換為GMT時間字符串的麻煩,后者則避免了把整數轉換為字符串的麻煩。

       HttpServletResponse還提供了許多設置

    setContentType:設置Content-Type頭。大多數Servlet都要用到這個方法。
    setContentLength:設置Content-Length頭。對于支持持久HTTP連接的瀏覽器來說,這個函數是很有用的。
    addCookie:設置一個Cookie(Servlet API中沒有setCookie方法,因為應答往往包含多個Set-Cookie頭)。
    另外,如上節介紹,sendRedirect方法設置狀態代碼302時也會設置Location頭。

       有關HTTP頭詳細和完整的說明,請參見http://www.w3.org/Protocols/規范。

    HTTP應答頭 說明
    Allow 服務器支持哪些請求方法(如GET、POST等)。

    Content-Encoding 文檔的編碼(Encode)方法。只有在解碼之后才可以得到Content-Type頭指定的內容類型。利用gzip壓縮文檔能夠顯著地減少HTML文檔的下載時間。Java的GZIPOutputStream可以很方便地進行gzip壓縮,但只有Unix上的Netscape和Windows上的IE 4、IE 5才支持它。因此,Servlet應該通過查看Accept-Encoding頭(即request.getHeader("Accept- Encoding"))檢查瀏覽器是否支持gzip,為支持gzip的瀏覽器返回經gzip壓縮的HTML頁面,為其他瀏覽器返回普通頁面。

    Content-Length 表示內容長度。只有當瀏覽器使用持久HTTP連接時才需要這個數據。如果你想要利用持久連接的優勢,可以把輸出文檔寫入 ByteArrayOutputStram,完成后查看其大小,然后把該值放入Content-Length頭,最后通過 byteArrayStream.writeTo(response.getOutputStream()發送內容。

    Content-Type 表示后面的文檔屬于什么MIME類型。Servlet默認為text/plain,但通常需要顯式地指定為text/html。由于經常要設置 Content-Type,因此HttpServletResponse提供了一個專用的方法setContentTyep。

    Date 當前的GMT時間。你可以用setDateHeader來設置這個頭以避免轉換時間格式的麻煩。

    Expires 應該在什么時候認為文檔已經過期,從而不再緩存它?

    Last-Modified 文檔的最后改動時間。客戶可以通過If-Modified-Since請求頭提供一個日期,該請求將被視為一個條件GET,只有改動時間遲于指定時間的文檔才會返回,否則返回一個304(Not Modified)狀態。Last-Modified也可用setDateHeader方法來設置。
    Location 表示客戶應當到哪里去提取文檔。Location通常不是直接設置的,而是通過HttpServletResponse的sendRedirect方法,該方法同時設置狀態代碼為302。

    Refresh 表示瀏覽器應該在多少時間之后刷新文檔,以秒計。除了刷新當前文檔之外,你還可以通過setHeader("Refresh", "5; URL=http://host/path")讓瀏覽器讀取指定的頁面。注意這種功能通常是通過設置HTML頁面HEAD區的<META HTTP-EQUIV="Refresh" CONTENT="5;URL=http://host/path">實現,這是因為,自動刷新或重定向對于那些不能使用CGI或Servlet的 HTML編寫者十分重要。但是,對于Servlet來說,直接設置Refresh頭更加方便。注意Refresh的意義是“N秒之后刷新本頁面或訪問指定頁面”,而不是“每隔N秒刷新本頁面或訪問指定頁面”。因此,連續刷新要求每次都發送一個Refresh頭,而發送204狀態代碼則可以阻止瀏覽器繼續刷新,不管是使用Refresh頭還是<META HTTP-EQUIV="Refresh" ...>。注意Refresh頭不屬于HTTP 1.1正式規范的一部分,而是一個擴展,但Netscape和IE都支持它。

    Server 服務器名字。Servlet一般不設置這個值,而是由Web服務器自己設置。

    Set-Cookie 設置和頁面關聯的Cookie。Servlet不應使用response.setHeader("Set-Cookie", ...),而是應使用HttpServletResponse提供的專用方法addCookie。參見下文有關Cookie設置的討論。

    WWW-Authenticate 客戶應該在Authorization頭中提供什么類型的授權信息?在包含401(Unauthorized)狀態行的應答中這個頭是必需的。例如,response.setHeader("WWW-Authenticate", "BASIC realm=\"executives\"")。注意Servlet一般不進行這方面的處理,而是讓Web服務器的專門機制來控制受密碼保護頁面的訪問(例如.htaccess)。

    本文來自CSDN博客,轉載請標明出處:http://blog.csdn.net/gideal_wang/archive/2009/07/10/4338646.aspx

    主站蜘蛛池模板: 国产成人免费ā片在线观看| 成人免费无码大片A毛片抽搐| 亚洲高清偷拍一区二区三区| 亚洲乱码日产精品一二三| 在线a级毛片免费视频| 亚洲女人18毛片水真多| 久久久久av无码免费网| 亚洲免费在线视频播放| AV免费网址在线观看| 亚洲精品自偷自拍无码| 免费国产在线观看老王影院| 男女啪啪免费体验区| 亚洲宅男天堂在线观看无病毒| 久久精品免费网站网| 午夜影视日本亚洲欧洲精品一区| 久久青草免费91线频观看不卡| 亚洲日韩图片专区第1页| 黄页网站免费观看| 久久精品亚洲日本波多野结衣 | 亚洲一级特黄大片在线观看| 免费国产草莓视频在线观看黄| 九月婷婷亚洲综合在线| 中文字幕不卡免费视频| 亚洲精品国产肉丝袜久久| 岛国av无码免费无禁网站| 黄床大片30分钟免费看| 亚洲色无码一区二区三区| **俄罗斯毛片免费| 久久久久久亚洲av无码蜜芽| 在线A亚洲老鸭窝天堂| 99精品在线免费观看| 亚洲色成人网站WWW永久四虎| 亚洲JIZZJIZZ中国少妇中文| 久久久久成人片免费观看蜜芽| 亚洲va成无码人在线观看| 亚洲一本大道无码av天堂| 97久久免费视频| 亚洲成a人片在线不卡一二三区| 国产精品亚洲综合专区片高清久久久| 最近中文字幕2019高清免费| 亚洲AV女人18毛片水真多|