亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

directory search
JSP 基礎(chǔ)教程 JSP 開發(fā)環(huán)境搭建 JSP 結(jié)構(gòu) JSP 生命周期 JSP 語法 JSP 指令 JSP 動(dòng)作元素 JSP 隱式對(duì)象 JSP 客戶端請(qǐng)求 JSP 服務(wù)器響應(yīng) JSP HTTP 狀態(tài)碼 JSP 表單處理 JSP 過濾器 JSP Cookies 處理 JSP Session JSP 文件上傳 JSP 日期處理 JSP 頁面重定向 JSP 點(diǎn)擊量統(tǒng)計(jì) JSP 自動(dòng)刷新 JSP 發(fā)送郵件 JSP 高級(jí)教程 JSP 標(biāo)準(zhǔn)標(biāo)簽庫(JSTL) <c:out> 標(biāo)簽 <c:set> 標(biāo)簽 <c:remove> 標(biāo)簽 <c:catch> 標(biāo)簽 <c:if> 標(biāo)簽 <c:choose> <c:import> 標(biāo)簽 <c:forEach> <c:param> 標(biāo)簽 <c:redirect> 標(biāo)簽 <fmt:formatNumber>標(biāo)簽 <fmt:parseNumber> 標(biāo)簽 <fmt:formatDate> 標(biāo)簽 <fmt:parseDate> 標(biāo)簽 <fmt:bundle> 標(biāo)簽 <fmt:setLocale> 標(biāo)簽 <fmt:setBundle> 標(biāo)簽 <fmt:timeZone> 標(biāo)簽 <fmt:setTimeZone> 標(biāo)簽 <fmt:message> 標(biāo)簽 <fmt:requestEncoding> 標(biāo)簽 <sql:setDataSource> 標(biāo)簽 <sql:query> 標(biāo)簽 <sql:update> 標(biāo)簽 <sql:param> 標(biāo)簽 <sql:dateParam> 標(biāo)簽 <sql:transaction> 標(biāo)簽 <x:out> 標(biāo)簽 <x:parse> 標(biāo)簽 <x:set> 標(biāo)簽 <x:if> 標(biāo)簽 <x:forEach> 標(biāo)簽 <x:choose> <x:transform> 標(biāo)簽 <x:param> 標(biāo)簽 fn:contains()函數(shù) fn:containsIgnoreCase()函數(shù) fn:endsWith()函數(shù) fn:escapeXml()函數(shù) fn:indexOf()函數(shù) fn:join()函數(shù) fn:length()函數(shù) fn:replace()函數(shù) fn:split()函數(shù) fn:startsWith()函數(shù) fn:substring()函數(shù) fn:substringAfter()函數(shù) fn:substringBefore()函數(shù) fn:toLowerCase()函數(shù) fn:toUpperCase()函數(shù) fn:trim()函數(shù) JSP 連接數(shù)據(jù)庫 JSP XML 數(shù)據(jù)處理 JSP JavaBean JSP 自定義標(biāo)簽 JSP 表達(dá)式語言 JSP 異常處理 JSP 調(diào)試 JSP 國際化
characters

JSP 客戶端請(qǐng)求


當(dāng)瀏覽器請(qǐng)求一個(gè)網(wǎng)頁時(shí),它會(huì)向網(wǎng)絡(luò)服務(wù)器發(fā)送一系列不能被直接讀取的信息,因?yàn)檫@些信息是作為HTTP信息頭的一部分來傳送的。您可以查閱HTTP協(xié)議來獲得更多的信息。

下表列出了瀏覽器端信息頭的一些重要內(nèi)容,在以后的網(wǎng)絡(luò)編程中將會(huì)經(jīng)常見到這些信息:

信息 描述
Accept 指定瀏覽器或其他客戶端可以處理的MIME類型。它的值通常為?image/png?或?image/jpeg
Accept-Charset 指定瀏覽器要使用的字符集。比如 ISO-8859-1
Accept-Encoding 指定編碼類型。它的值通常為?gzip?或compress
Accept-Language 指定客戶端首選語言,servlet會(huì)優(yōu)先返回以當(dāng)前語言構(gòu)成的結(jié)果集,如果servlet支持這種語言的話。比如 en,en-us,ru等等
Authorization 在訪問受密碼保護(hù)的網(wǎng)頁時(shí)識(shí)別不同的用戶
Connection 表明客戶端是否可以處理HTTP持久連接。持久連接允許客戶端或?yàn)g覽器在一個(gè)請(qǐng)求中獲取多個(gè)文件。Keep-Alive?表示啟用持久連接
Content-Length 僅適用于POST請(qǐng)求,表示 POST 數(shù)據(jù)的字節(jié)數(shù)
Cookie 返回先前發(fā)送給瀏覽器的cookies至服務(wù)器
Host 指出原始URL中的主機(jī)名和端口號(hào)
If-Modified-Since 表明只有當(dāng)網(wǎng)頁在指定的日期被修改后客戶端才需要這個(gè)網(wǎng)頁。 服務(wù)器發(fā)送304碼給客戶端,表示沒有更新的資源
If-Unmodified-Since 與If-Modified-Since相反, 只有文檔在指定日期后仍未被修改過,操作才會(huì)成功
Referer 標(biāo)志著所引用頁面的URL。比如,如果你在頁面1,然后點(diǎn)了個(gè)鏈接至頁面2,那么頁面1的URL就會(huì)包含在瀏覽器請(qǐng)求頁面2的信息頭中
User-Agent 用來區(qū)分不同瀏覽器或客戶端發(fā)送的請(qǐng)求,并對(duì)不同類型的瀏覽器返回不同的內(nèi)容

HttpServletRequest類

request對(duì)象是javax.servlet.http.HttpServletRequest類的實(shí)例。每當(dāng)客戶端請(qǐng)求一個(gè)頁面時(shí),JSP引擎就會(huì)產(chǎn)生一個(gè)新的對(duì)象來代表這個(gè)請(qǐng)求。

request對(duì)象提供了一系列方法來獲取HTTP信息頭,包括表單數(shù)據(jù),cookies,HTTP方法等等。

接下來將會(huì)介紹一些在JSP編程中常用的獲取HTTP信息頭的方法。詳細(xì)內(nèi)容請(qǐng)見下表:

序號(hào) 方法& 描述
1 Cookie[] getCookies() 返回客戶端所有的Cookie的數(shù)組
2 Enumeration getAttributeNames() 返回request對(duì)象的所有屬性名稱的集合
3 Enumeration getHeaderNames() 返回所有HTTP頭的名稱集合
4 Enumeration getParameterNames() 返回請(qǐng)求中所有參數(shù)的集合
5 HttpSession getSession() 返回request對(duì)應(yīng)的session對(duì)象,如果沒有,則創(chuàng)建一個(gè)
6 HttpSession getSession(boolean create) 返回request對(duì)應(yīng)的session對(duì)象,如果沒有并且參數(shù)create為true,則返回一個(gè)新的session對(duì)象
7 Locale getLocale() 返回當(dāng)前頁的Locale對(duì)象,可以在response中設(shè)置
8 Object getAttribute(String name) 返回名稱為name的屬性值,如果不存在則返回null。
9 ServletInputStream getInputStream() 返回請(qǐng)求的輸入流
10 String getAuthType() 返回認(rèn)證方案的名稱,用來保護(hù)servlet,比如 "BASIC" 或者 "SSL" 或 null 如果 JSP沒設(shè)置保護(hù)措施
11 String getCharacterEncoding() 返回request的字符編碼集名稱
12 String getContentType() 返回request主體的MIME類型,若未知?jiǎng)t返回null
13 String getContextPath() 返回request URI中指明的上下文路徑
14 String getHeader(String name) 返回name指定的信息頭
15 String getMethod() 返回此request中的HTTP方法,比如 GET,,POST,或PUT
16 String getParameter(String name) 返回此request中name指定的參數(shù),若不存在則返回null
17 String getPathInfo() 返回任何額外的與此request URL相關(guān)的路徑
18 String getProtocol() 返回此request所使用的協(xié)議名和版本
19 String getQueryString() 返回此 request URL包含的查詢字符串
20 String getRemoteAddr() 返回客戶端的IP地址
21 String getRemoteHost() 返回客戶端的完整名稱
22 String getRemoteUser() 返回客戶端通過登錄認(rèn)證的用戶,若用戶未認(rèn)證則返回null
23 String getRequestURI() 返回request的URI
24 String getRequestedSessionId() 返回request指定的session ID
25 String getServletPath() 返回所請(qǐng)求的servlet路徑
26 String[] getParameterValues(String name) 返回指定名稱的參數(shù)的所有值,若不存在則返回null
27 boolean isSecure() 返回request是否使用了加密通道,比如HTTPS
28 int getContentLength() 返回request主體所包含的字節(jié)數(shù),若未知的返回-1
29 int getIntHeader(String name) 返回指定名稱的request信息頭的值
30 int getServerPort() 返回服務(wù)器端口號(hào)

HTTP信息頭示例

在這個(gè)例子中,我們會(huì)使用HttpServletRequest類的getHeaderNames()方法來讀取HTTP信息頭。這個(gè)方法以枚舉的形式返回當(dāng)前HTTP請(qǐng)求的頭信息。

獲取Enumeration對(duì)象后,用標(biāo)準(zhǔn)的方式來遍歷Enumeration對(duì)象,用hasMoreElements()方法來確定什么時(shí)候停止,用nextElement()方法來獲得每個(gè)參數(shù)的名字。

<%@ page import="java.io.*,java.util.*" %>
<html>
<head>
<title>HTTP Header Request Example</title>
</head>
<body>
<center>
<h2>HTTP Header Request Example</h2>
<table width="100%" border="1" align="center">
<tr bgcolor="#949494">
<th>Header Name</th><th>Header Value(s)</th>
</tr>
<%
   Enumeration headerNames = request.getHeaderNames();
   while(headerNames.hasMoreElements()) {
      String paramName = (String)headerNames.nextElement();
      out.print("<tr><td>" + paramName + "</td>\n");
      String paramValue = request.getHeader(paramName);
      out.println("<td> " + paramValue + "</td></tr>\n");
   }
%>
</table>
</center>
</body>
</html>

訪問main.jsp,將會(huì)得到以下結(jié)果:

    <p id="5jzha"></p>

    <s id="5jzha"></s>

        Header Name Header Value(s)
        accept * } }

        編譯LogFilter.java文件,然后將編譯后的class文件放在<Tomcat安裝目錄>/webapps/ROOT/WEB-INF/classes目錄下。


        web.xml文件中的JSP過濾器映射

        過濾器被定義,然后映射成一個(gè)URL或JSP文件名,與servlet被定義然后映射的方式差不多。在部署描述文件web.xml中,使用<filter>標(biāo)簽來進(jìn)行過濾器映射:

        <filter>
           <filter-name>LogFilter</filter-name>
           <filter-class>LogFilter</filter-class>
           <init-param>
        	  <param-name>test-param</param-name>
        	  <param-value>Initialization Paramter</param-value>
           </init-param>
        </filter>
        <filter-mapping>
           <filter-name>LogFilter</filter-name>
           <url-pattern>*
        Accept-Encoding: gzip
        Accept-Language: en
        Accept-Charset: iso-8859-1,*,utf-8
        Cookie: name=xyz
        

        JSP腳本通過request對(duì)象中的getCookies()方法來訪問這些cookies,這個(gè)方法會(huì)返回一個(gè)Cookie對(duì)象的數(shù)組。


        Servlet Cookies 方法

        下表列出了Cookie對(duì)象中常用的方法:

        序號(hào) 方法 & 描述
        1 public void setDomain(String pattern) 設(shè)置cookie的域名,比如shouce.ren
        2 public String getDomain() 獲取cookie的域名,比如shouce.ren
        3 public void setMaxAge(int expiry) 設(shè)置cookie有效期,以秒為單位,默認(rèn)有效期為當(dāng)前session的存活時(shí)間
        4 public int getMaxAge() 獲取cookie有效期,以秒為單位,默認(rèn)為-1 ,表明cookie會(huì)活到瀏覽器關(guān)閉為止
        5 public String getName() 返回 cookie的名稱,名稱創(chuàng)建后將不能被修改
        6 public void setValue(String newValue) 設(shè)置 cookie的值
        7 public String getValue() 獲取cookie的值
        8 public void setPath(String uri) 設(shè)置cookie 的路徑,默認(rèn)為當(dāng)前頁面目錄下的所有URL,還有此目錄下的所有子目錄
        9 public String getPath() 獲取cookie 的路徑
        10 public void setSecure(boolean flag) 指明cookie是否要加密傳輸
        11 public void setComment(String purpose) 設(shè)置注釋描述 cookie的目的。當(dāng)瀏覽器將cookie展現(xiàn)給用戶時(shí),注釋將會(huì)變得非常有用
        12 public String getComment() 返回描述cookie目的的注釋,若沒有則返回null

        使用JSP設(shè)置Cookies

        使用JSP設(shè)置cookie包含三個(gè)步驟:

        (1)創(chuàng)建一個(gè)Cookie對(duì)象: 調(diào)用Cookie的構(gòu)造函數(shù),使用一個(gè)cookie名稱和值做參數(shù),它們都是字符串。

        Cookie cookie = new Cookie("key","value");
        

        請(qǐng)務(wù)必牢記,名稱和值中都不能包含空格或者如下的字符:

        [ ] ( ) = , " / ? @ : ;
        

        (2) 設(shè)置有效期:調(diào)用setMaxAge()函數(shù)表明cookie在多長(zhǎng)時(shí)間(以秒為單位)內(nèi)有效。下面的操作將有效期設(shè)為了24小時(shí)。

        cookie.setMaxAge(60*60*24); 
        

        (3) 將cookie發(fā)送至HTTP響應(yīng)頭中:調(diào)用response.addCookie()函數(shù)來向HTTP響應(yīng)頭中添加cookies。

        response.addCookie(cookie);
        

        實(shí)例演示

        <%
           // 為 first_name 和 last_name設(shè)置cookie      
           Cookie firstName = new Cookie("first_name",
         			  request.getParameter("first_name"));
           Cookie lastName = new Cookie("last_name",
        			  request.getParameter("last_name"));
        
           // 設(shè)置cookie過期時(shí)間為24小時(shí)。
           firstName.setMaxAge(60*60*24); 
           lastName.setMaxAge(60*60*24); 
        
           // 在響應(yīng)頭部添加cookie
           response.addCookie( firstName );
           response.addCookie( lastName );
        %>
        <html>
        <head>
        <title>Setting Cookies</title>
        </head>
        <body>
        <center>
        <h1>Setting Cookies</h1>
        </center>
        <ul>
        <li><p><b>First Name:</b>
           <%= request.getParameter("first_name")%>
        </p></li>
        <li><p><b>Last  Name:</b>
           <%= request.getParameter("last_name")%>
        </p></li>
        </ul>
        </body>
        </html>
        

        將上面兩個(gè)文件放在<Tomcat安裝目錄>/webapps/ROOT目錄下,然后訪問http://localhost:8080/hello.jsp,將會(huì)得到如下輸出結(jié)果:

        試著輸入First Name和Last Name,然后點(diǎn)擊提交按鈕,它將會(huì)在您的屏幕中顯示first name和last name,并且設(shè)置first name和last name兩個(gè)cookie,下一次點(diǎn)擊提交按鈕時(shí)會(huì)發(fā)給服務(wù)器。


        使用JSP讀取Cookies

        想要讀取cookies,您就需要調(diào)用request.getCookies()方法來獲得一個(gè)javax.servlet.http.Cookie對(duì)象的數(shù)組,然后遍歷這個(gè)數(shù)組,使用getName()方法和getValue()方法來獲取每一個(gè)cookie的名稱和值。

        讓我們來讀取上個(gè)例子中的cookies。

        <html>
        <head>
        <title>Reading Cookies</title>
        </head>
        <body>
        <center>
        <h1>Reading Cookies</h1>
        </center>
        <%
           Cookie cookie = null;
           Cookie[] cookies = null;
           // 獲取cookies的數(shù)據(jù),是一個(gè)數(shù)組
           cookies = request.getCookies();
           if( cookies != null ){
              out.println("<h2> Found Cookies Name and Value</h2>");
              for (int i = 0; i < cookies.length; i++){
                 cookie = cookies[i];
                 out.print("Name : " + cookie.getName( ) + ",  ");
                 out.print("Value: " + cookie.getValue( )+" <br/>");
              }
          }else{
              out.println("<h2>No cookies founds</h2>");
          }
        %>
        </body>
        </html>
        

        如果您把first name cookie設(shè)置成"John",last name設(shè)置成"Player",訪問 http://localhost:8080/main.jsp,將會(huì)得到如下輸出結(jié)果:

        Found Cookies Name and Value
        Name : first_name, Value: John 
        Name : last_name, Value: Player
        

        使用JSP刪除Cookies

        刪除cookies非常簡(jiǎn)單。如果您想要?jiǎng)h除一個(gè)cookie,按照下面給的步驟來做就行了:

        • 獲取一個(gè)已經(jīng)存在的cookie然后存儲(chǔ)在Cookie對(duì)象中。
        • 將cookie的有效期設(shè)置為0。
        • 將這個(gè)cookie重新添加進(jìn)響應(yīng)頭中。

        實(shí)例演示

        下面的程序刪除一個(gè)名為"first_name"的cookie,當(dāng)您下次運(yùn)行main.jsp時(shí),first_name將會(huì)為null。

        <html>
        <head>
        <title>Reading Cookies</title>
        </head>
        <body>
        <center>
        <h1>Reading Cookies</h1>
        </center>
        <%
           Cookie cookie = null;
           Cookie[] cookies = null;
           // 獲取當(dāng)前域名下的cookies,是一個(gè)數(shù)組
           cookies = request.getCookies();
           if( cookies != null ){
              out.println("<h2> Found Cookies Name and Value</h2>");
              for (int i = 0; i < cookies.length; i++){
                 cookie = cookies[i];
                 if((cookie.getName( )).compareTo("first_name") == 0 ){
                    cookie.setMaxAge(0);
                    response.addCookie(cookie);
                    out.print("Deleted cookie: " + 
                    cookie.getName( ) + "<br/>");
                 }
                 out.print("Name : " + cookie.getName( ) + ",  ");
                 out.print("Value: " + cookie.getValue( )+" <br/>");
              }
          }else{
              out.println(
              "<h2>No cookies founds</h2>");
          }
        %>
        </body>
        </html>
        

        訪問它,將會(huì)得到如下輸出結(jié)果:

        Cookies Name and Value
        Deleted cookie : first_name
        Name : first_name, Value: John
        Name : last_name, Value: Player
        

        再次訪問http://localhost:8080/main.jsp,將會(huì)得到如下結(jié)果:

        Found Cookies Name and Value
        Name : last_name, Value: Player
        

        您也可以手動(dòng)在瀏覽器中刪除cookies。點(diǎn)擊Tools菜單項(xiàng),然后選擇Internet Options,點(diǎn)擊Delete Cookies,就能刪除所有cookies了。

        關(guān)于我們 聯(lián)系我們 留言板

        手冊(cè)網(wǎng)

        Previous article: Next article:
          • <legend id="5jzha"><var id="5jzha"><th id="5jzha"></th></var></legend>
              <s id="5jzha"><strong id="5jzha"></strong></s>