jsp數據交互(一)


 jsp內置對象這里看別人的總結http://www.cnblogs.com/xiaotangtang/p/4943610.html 

 

一、jsp中java小腳本
    1.<% java代碼段%>
    2.<% =java表達式%>不能有分號
    3.<%!成員變量和函數聲明%>
二、注釋
    1.<!--html注釋-->客戶端可以看到
    2.<%--jsp注釋--%>客戶端不能看到
三、jsp頁面的的執行過程
    1.客戶端請求(輸入URL)
    2.服務器
       (1)現將jsp翻譯成.java文件(第一次請求)
            如果是第二次請求,並且jsp頁面內容未改變
       (2)將java文件編譯成.class文件
       (3)執行.class文件
    3.將執行后的結果和html靜態內容發送到客戶端
    4.斷開連接
四、jsp內置對象
  是由web容器創建的對象,可以直接用,不用再new
     1.out:方法print(文本)向客戶端輸出內容
     2.request:客戶端請求內容
        方法:
            getParameter(“鍵”),獲取客戶端提交的單個數據
            getParameterValues(“鍵”)獲取客戶端提交的多個數據
            setCharacterEncoding("編碼")解決post提交方式的亂碼
            getRequestDispatcher("頁面"):進行頁面轉發
      3.response:響應客戶端的請求,向客戶端輸出內容
         方法
         sendRedirect("頁面");//進行頁面重定向

六、會話:session
     瀏覽器與服務器的一次通話(類似一次打電話)
     1.會話跟瀏覽器是一一對應的
     2.同一個瀏覽器不同請求是一次會話
     3.不同瀏覽器就是不同會話
     4.一般用於保存客戶端特定的信息(臨時)
  session失效:
     1.原則上,瀏覽器關閉,session就失效(實際過程中不一定)
     2.超過有效期失效
     3.調用invalidate(),立即失效
    方法:
       setAttribute(String key,object value),向session保存數據
       object setAttribute(String key)向session讀取數據
       setMaxInactiveIntervals設置有效期
       invalidate()使session失效
       removeAttribute(String key)移除指定的session
七、inlude指令:將頁面信息包含到另一個頁面(靜態包含)
    <%@ include file="頁面"%>
八、application:應用程序級別的對象
   各個客戶端共享的數據
       方法:
          setAttribute(String key ,object value)
          getAttribute(String key)
          getRealPath("虛擬路徑");根據虛擬路徑獲取物理路徑
九、Cookie: 保存特定客戶端的信息
    用法:
      1.創建
        Cookie ck=new Cookie(String key,String value)
        ck.setMaxAge("時間"),設置有效時間,不設置默認瀏覽器關閉時失效
      2.保存
        response.addCookie(ck);
      3.讀取cookie
         a.Cookie[]cks=request.getCookies();
         b.遍歷
           getName():獲取當前cookie的名字(鍵名)
           getValue():獲取當前cookie的值
十、session與cookie的區別
          session                    cookie
    保存在服務器的內存中         保存在客戶端的硬盤上
    保存object類型               保存String類型
    保存臨時數據                 保存永久數據
    安全性高                     安全性差
十一、JavaBean
   是一個java類
   從功能上來說,java類分為:業務類和數據類
   一個java類符合以下要求才是JavaBean:
        1.是一個公有類
        2.有無參的公共的構造方法
        3.屬性私有:第一個字母小寫
        4.有getter和setter方法
            (方法名格式:get屬性名(大寫),set屬性名(大寫))

 

Validate:驗證
Context:上下文
Request:請求  :當前請求(別的請求無效)
Response:響應
Redirect:重定向
Session:會話:當前會話 (可以包含多個請求)在該會話有效期內可以訪問
Application:當前服務器(可以包含多個會話):
當服務器啟動后就會創建一個application對象,被所有用戶共享
page、request、session、application四個作用域對象都有
setAttribute()和getAttribute()方法
而且作用域范圍越來越大

 

1:request對象

是從客戶端向服務器端發出請求,包括用戶提交的信息以及客戶端的一些信息。request對象是javax.servlet.http.HttpServletRequest類的實現實例。

request對象封裝了瀏覽器的請求信息,通過request對象的各種方法可以獲取客戶端以及用戶提交的各項請求信息。

使用request對象獲取客戶端提交的請求參數的常用方法如下:

1.String getParameter(String name),獲取上一頁面所提交的參數值的參數值,並以字符串形式返回指定參數的值,如果參數不存在則返回空值。用於表單、鏈接或網址欄傳遞參數時,使用此方法。

例如,獲取客戶端name的參數值:

String name = request.getParameter("name");

2.String[ ] getParameterValues(String name),獲取以相同名稱命名的表單組件提交的數據,主要用於獲取復選框的值,返回值類型是字符串數組String[ ]

例如,獲取客戶端hobby復選框的所有取值:

String[ ] hobbys = request.getParameterValues("hobby");
       if(hobbys != null)
       {
       out.println("您的愛好有:");
       for(int i=0;i<hobbys.length;i++)
          out.println(hobbys[i]);
       }

3.void setCharacterEncoding(String encoding),設置字符編碼方式,用來解決傳遞非英文字符所出現的亂碼問題。

對於以post提交的表單數據

在第一行寫:
request.setCharacterEncoding("UTF-8");

對於以get提交的表單數據

提交的數據作為查詢字符串被附加到URL 的末端發送到服務器,此時字服務器端調用

setCharacterEncoding()方法就沒有作用了,我們需要得到請求參數值之后,進行編碼轉換

String name=request.getParameter("name");

name=new String(name.getBytes("ISO-8859-1"),"UTF-8"); 
也可以通過TomCat目錄下的conf下的server.xml文件,在<Connector>元素中添加URIEncoding 屬性,將它的值設置為“utf-8”

<Connector

    port="8080"

    protocol="HTTP/1.1"

     reidrectPort="8433"

    URIEncoding ="UTF-8"

/>

4.RequestDispatcher getRequestDispatcher(String path)----獲取請求分配器

返回一個javax.servlet.RequestDispatcher對象該方法的forward()方法用於 轉發請求

例如,request.setCharacterEncoding("UTF-8");

實例:使用request對象實現用戶注冊功能

zhuce.html源代碼如下:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <title>個人信息注冊</title>
 
    <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
    <meta http-equiv="description" content="this is my page">
    <meta http-equiv="content-type" content="text/html; charset=UTF-8">
   
    <!--<link rel="stylesheet" type="text/css" href="./styles.css">-->

  </head>
 
  <body>
    <h1 align="center">個人信息注冊</h1>
    <form action="zhuce.jsp" method="post">
        姓名:<input type="text" name="name"><br>
        密碼:<input type="password" name="pwd"><br>
        請選擇你的職業:
        <input type="radio" name="career" value="農民">農民
     <input type="radio" name="career" value="工人">工人
     <input type="radio" name="career" value="學生" checked>學生
     <input type="radio" name="career" value="教師">教師
     <br>
     你喜歡的城市:
     <select name="city">
       <option value="遼寧省">遼寧省</option>
       <option value="湖北省">湖北省</option>
       <option value="河南省">河南省</option>
       <option value="山東省">山東省</option>
       <option value="江蘇省">江蘇省</option>
       <option value="湖南省" selected>湖南省</option>
     </select>
     <br>
     請選擇你的愛好:
     <input type="checkbox" name="hobby" value="旅游">旅游
     <input type="checkbox" name="hobby" value="看書" checked>看書
     <input type="checkbox" name="hobby" value="游戲">游戲
     <input type="checkbox" name="hobby" value="琴棋書畫">琴棋書畫
     <br>
     自我介紹:
     <textarea name="intro">自我介紹</textarea>
     <br>
     <input type="submit" name="submit" value="提交">
    </form>
  </body>
</html>
zhuce.jsp源代碼如下:

<%@ page language="java" import="java.util.*" contentType="text/html;charset=UTF-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    
   
    <title>個人信息注冊</title>
   

  </head>
 
  <body>
    <%request.setCharacterEncoding("UTF-8"); %>
     您的姓名是:<%=request.getParameter("name") %><br>
     您的密碼是:<%=request.getParameter("pwd") %><br>
     您的職業是:<%=request.getParameter("career") %><br>
     您喜歡的城市是:<%=request.getParameter("city") %><br>
     您的愛好有:<%String[] hobbys = request.getParameterValues("hobby");
       if(hobbys != null)
       {
       out.println("您的愛好有:");
       for(int i=0;i<hobbys.length;i++)
          out.print(hobbys[i]);
       }
      %>
      <br>
     自我介紹:<%=request.getParameter("intro") %><br>
  </body>
</html>

2:response對象
常用方法:
void addCookie(Cookie cookie):在客戶端添加cookie
void sentRedirect(String location);重新定位到新的URL
 

getRequestDispatcher()與sendRedirect()的區別

 

1.request.getRequestDispatcher()是請求轉發,前后頁面共享一個request ;
response.sendRedirect()是重新定向,前后頁面不是一個request。

request.getRequestDispather();返回的是一個RequestDispatcher對象。

2.RequestDispatcher.forward()是在服務器端運行;
HttpServletResponse.sendRedirect()是通過向客戶瀏覽器發送命令來完成.
所以RequestDispatcher.forward()對於瀏覽器來說是“透明的”;
而HttpServletResponse.sendRedirect()則不是。

 

3.ServletContext.getRequestDispatcher(String url)中的url只能使用絕對路徑; 而

ServletRequest.getRequestDispatcher(String url)中的url可以使用相對路徑。因為

ServletRequest具有相對路徑的概念;而ServletContext對象無次概念。

 

RequestDispatcher對象從客戶端獲取請求request,並把它們傳遞給服務器上的servlet,html或

jsp。它有兩個方法:


1.void forward(ServletRequest request,ServletResponse response)
用來傳遞request的,可以一個Servlet接收request請求,另一個Servlet用這個request請求來產生response。request傳遞的請求,response是客戶端返回的信息。forward要在response到達客戶端之前調用,也就是 before response body output has been flushed。如果不是的話,它會報出異常。


2.void include(ServletRequest request,ServletResponse response)
用來記錄保留request和response,以后不能再修改response里表示狀態的信息。

 

如果需要把請求轉移到另外一個Web App中的某個地址,可以按下面的做法:
1. 獲得另外一個Web App的ServletConext對象(currentServletContext.getContext(uripath)).

2. 調用ServletContext.getRequestDispatcher(String url)方法。

eg:ServletContext.getRequestDispatcher("smserror.jsp").forward(request,response);

 

http://lanew.blog.ccidnet.com/blog-htm-do-showone-type-blog-itemid-3690834-uid-327434.html

 

二者區別:
response.sendRedirect(url)跳轉到指定的URL地址,產生一個新的request,所以要傳遞參數只有在url后加參
數,如:
url?id=1.
request.getRequestDispatcher(url).forward(request,response)是直接將請求轉發到指定URL,所以該請求
能夠直接獲得上一個請求的數據,也就是說采用請求轉發,request對象始終存在,不會重新創建。而
sendRedirect()會新建request對象,所以上一個request中的數據會丟失。
更具體來說就是這樣的:
redirect 會首先發一個response給瀏覽器, 然后瀏覽器收到這個response后再發一個requeset給服務器, 然后
服務器發新的response給瀏覽器. 這時頁面收到的request是一個新從瀏覽器發來的.
forward 發生在服務器內部, 在瀏覽器完全不知情的情況下發給了瀏覽器另外一個頁面的response. 這時頁面
收到的request不是從瀏覽器直接發來了,可能己經用request.setAttribute在request里放了數據.在轉到的頁
面可直接用request.getAttribute獲得數據。
最基本的用法就如上了,其他的一些應注意的地方如下:
跳轉方式
http://localhost:8080/Test應用
運用forward方法只能重定向到同一個Web應用程序中的一個資源。而sendRedirect方法可以讓你重定向到任何
URL。
表單form的action="/uu";sendRedirect("/uu");表示相對於服務器根路徑。如 http://localhost:8080/Test
用(則提交至 http://localhost:8080/uu);
Forward代碼中的"/uu"則代表相對與WEB應用的路徑。如 http://localhost:8080/Test應用(則提交至
http://localhost:8080/Test/uu);
(運用RequestDispatcher接口的Forward)方法
forward()無法重定向至有frame的jsp文件,可以重定向至有frame的html文件,
同時forward()無法在后面帶參數傳遞,比如servlet?name=frank,這樣不行,可以程序內通過
response.setAttribute("name",name)來傳至下一個頁面.
重定向后瀏覽器地址欄URL不變.
只有在客戶端沒有輸出時才可以調用forward方法。如果當前頁面的緩沖區(buffer)不是空的,那么你在調用
forward方法前必須先清空緩沖區。
"/"代表相對與web應用路徑
RequestDispatcher rd = request.getRequestDispatcher("/ooo");
rd.forward(request, response);提交至 http://localhost:8080/Test/ooo
RequestDispatcher rd = getServletContext().getRequestDispatcher("/ooo");
rd.forward(request, response);提交至 http://localhost:8080/Test/ooo
RequestDispatcher rd =getServletContext().getNamedDispatcher("TestServlet");(TestServlet為一個
<servlet-name>)
rd.forward(request, response);提交至名為TestServlet的servlet
如果在<jsp:forward>之前有很多輸出,前面的輸出已使緩沖區滿,將自動輸出到客戶端,那么該語句將不起作用,
這一點應該特別注意。
另外要注意:它不能改變瀏覽器地址,刷新的話會導致重復提交
http://localhost:8080/Test/gw/page.jsp中轉發
<jsp:forward page="OtherPage.jsp"/>在JSP頁面被解析后轉換成pageContext.forward("OtherPage.jsp");
"/OtherPage.jsp"提交到 http://localhost:8080/Test/OtherPage.jsp
"OtherPage.jsp"提交到 http://localhost:8080/Test/gw/OtherPage.jsp
(運用HttpServletResponse接口的sendRedirect)方法302
是在用戶的瀏覽器端工作,sendRedirect()可以帶參數傳遞,比如servlet?name=frank傳至下個頁面,
同時它可以重定向至不同的主機上,sendRedirect()可以重定向有frame.的jsp文件.
假設轉發代碼包含於注冊的servlet-url為/ggg/tt;jsp為/ggg/tt.jsp:
絕對路徑:response.sendRedirect(" http://www.brainysoftware.com
根路徑:response.sendRedirect("/ooo")發送至 http://localhost:8080/ooo
相對路徑:response.sendRedirect("ooo")發送至 http://localhost:8080/Test/ggg/ooo,
sendRedirect等同於此方式
response.setStatus(HttpServletResponse.SC_MOVED_PERMANENTLY);
String newLocn = "/newpath/jsa.jsp";
response.setHeader("Location",newLocn);
(Meta Refresh)方法200
這種方法是由HTML提供的,Meta本身就是HTML標簽。使用方法是:<meta http-equiv="refresh" content="5;
url=http://www.dreamdu.com/" />
相應的java代碼
String content=stayTime+";URL="+URL;
response.setHeader("REFRESH",content);
------------------------------------------------------------------------------------------------
--------------------------
使用response.sendRedirect()地址欄將改變
使用request.getRequestDispatcher().forward(request,response)地址欄中的信息保持不變.
------------------------------------------------------------------------------------------------
--------------------------
request.setAttribute存的東西
只用通過方法2跳轉 才能在新頁取出來

1.request.getRequestDispatcher()是請求轉發,前后頁面共享一個request ; 
response.sendRedirect()是重新定向,前后頁面不是一個request。

2.RequestDispatcher.forward()是在服務器端運行; 
HttpServletResponse.sendRedirect()是通過向客戶瀏覽器發送命令來完成. 

3.ServletContext.getRequestDispatcher(String url)中的url只能使用絕對路徑; 而

ServletRequest.getRequestDispatcher(String url)中的url可以使用相對路徑。因為

ServletRequest具有相對路徑的概念;而ServletContext對象無此概念。

RequestDispatcher對象從客戶端獲取請求request,並把它們傳遞給服務器上的servlet,html或

jsp。它有兩個方法:


2.void include(ServletRequest request,ServletResponse response) 
用來記錄保留request和response,以后不能再修改response里表示狀態的信息。

 

二者區別: 
response.sendRedirect(url)跳轉到指定的URL地址,產生一個新的request,所以要傳遞參數只有在url后加參 
數,如: 
url?id=1. 
request.getRequestDispatcher(url).forward(request,response)是直接將請求轉發到指定URL,所以該請求 
能夠直接獲得上一個請求的數據,也就是說采用請求轉發,request對象始終存在,不會重新創建。而 
sendRedirect()會新建request對象,所以上一個request中的數據會丟失。 
更具體來說就是這樣的: 
redirect 會首先發一個response給瀏覽器, 然后瀏覽器收到這個response后再發一個requeset給服務器, 然后 
服務器發新的response給瀏覽器. 這時頁面收到的request是一個新從瀏覽器發來的. 
forward 發生在服務器內部, 在瀏覽器完全不知情的情況下發給了瀏覽器另外一個頁面的響應. 這時頁面 
收到的request不是從瀏覽器直接發來了,可能己經用request.setAttribute在request里放了數據.在轉到的頁 
面可直接用request.getAttribute獲得數據。 


 
 
重定向的重要應用:
 
使用重定向技術實現超鏈接的數據傳遞
<a href="color.jsp?color=黃色">黃色</a>  
 
使用超鏈接進行數據傳遞時,采用的是get方式提交請求,如果在傳遞數據中存在中文,就會造成亂碼,因為request.setCharacterEncoding("utf-8")只適用於post方法提交 所以可以通過 設置tomcat字符集實現
當傳遞多個數據時,可以用&連接
<a href="color.jsp?color=黃色&id=1">黃色</a>  

Session
//設置10分鍾后失效
session.setMaxInactiveInterval(10*60);  
也可以在項目的web.xml中設置  代碼片段如下:
<session-config>
    <session-timeout>30</session-timeout>       ------這里的單位是分鍾  系統默認會話超時是30分鍾  0表示失效   -1表示永不超時
</session-config>
 
使整個session會話失效:session.invalidate();
如果只想清空session的某個對象 ,則可以調用session.removeAttribute(String key)方法,將指定的對象從session中清除
此時session對象仍然有效
1、概念:Session代表服務器與瀏覽器的一次會話過程,這個過程是連續的,也可以時斷時續的。在Servlet中,session指的是HttpSession類的對象,這個概念到此結束了,也許會很模糊,但只有看完本文,才能真正有個深刻理解。
 
2、Session創建的時間是:
JSP文件在編譯成Servlet時將會自動加上這樣一條語句 HttpSession session = HttpServletRequest.getSession(true);這也是JSP中隱含的 session對象的來歷。
由於session會消耗內存資源,因此,如果不打算使用session,應該在所有的JSP中關閉它。
 
引申:
2)、當JSP頁面沒有顯式禁止session的時候,在打開瀏覽器第一次請求該jsp的時候,服務器會自動為其創建一個session,並賦予其一個sessionID,發送給客戶端的瀏覽器。以后客戶端接着請求本應用中其他資源的時候,會自動在請求頭上添加:
Cookie:JSESSIONID=客戶端第一次拿到的session ID
這樣,服務器端在接到請求時候,就會收到session ID,並根據ID在內存中找到之前創建的session對象,提供給請求使用。這也是session使用的基本原理----搞不懂這個,就永遠不明白session的原理。
下面是兩次請求同一個jsp,請求頭信息:
通過圖可以清晰發現,第二次請求的時候,已經添加session ID的信息。
 
3、Session刪除的時間是:
1)Session超時:超時指的是連續一定時間服務器沒有收到該Session所對應客戶端的請求,並且這個時間超過了服務器設置的Session超時的最大時間。
2)程序調用HttpSession.invalidate()
3)服務器關閉或服務停止
 
4、session存放在哪里:服務器端的內存中。不過session可以通過特殊的方式做持久化管理。
 
5、session的id是從哪里來的,sessionID是如何使用的:當客戶端第一次請求session對象時候,服務器會為客戶端創建一個session,並將通過特殊算法算出一個session的ID,用來標識該session對象,當瀏覽器下次(session繼續有效時)請求別的資源的時候,瀏覽器會偷偷地將sessionID放置到請求頭中,服務器接收到請求后就得到該請求的sessionID,服務器找到該id的session返還給請求者(Servlet)使用。一個會話只能有一個session對象,對session來說是只認id不認人。
 
6、session會因為瀏覽器的關閉而刪除嗎?
不會,session 存在於服務器內存中

ServletContext application=this.getServletContext();
            List<User> listUser = (List<User>)application.getAttribute("currentListUser");
            if(listUser == null){
                listUser = new ArrayList<User>();
            }
            listUser.add(user);
            application.setAttribute("currentListUser", listUser);  
 
 
 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM