jsp數據交互(一)

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

 

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

6、會話: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
7、inlude指令:將頁面信息包含到另外一個頁面(靜態包含)
    <%@ include file="頁面"%>
8、application:應用程序級別的對象
   各個客戶端共享的數據
       方法:
          setAttribute(String key ,object value)
          getAttribute(String key)
          getRealPath("虛擬路徑");根據虛擬路徑獲取物理路徑
9、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的值
10、session與cookie的區別
          session                    cookie
    保存在服務器的內存中         保存在客戶端的硬盤上
    保存object類型               保存String類型
    保存臨時數據                 保存永久數據
    安全性高                     安全性差
11、JavaBean
   是一個java類
   從功能上來講,java類分爲:業務類和數據類
   一個java類符合如下要求才是JavaBean:
        1.是一個公有類
        2.有無參的公共的構造方法
        3.屬性私有:第一個字母小寫
        4.有getter和setter方法
            (方法名格式:get屬性名(大寫),set屬性名(大寫))html

 

Validate:驗證
Context:上下文
Request:請求  :當前請求(別的請求無效)
Response:響應
Redirect:重定向
Session:會話:當前會話 (能夠包含多個請求)在該會話有效期內能夠訪問
Application:當前服務器(能夠包含多個會話):
當服務器啓動後就會建立一個application對象,被全部用戶共享
page、request、session、application四個做用域對象都有
setAttribute()和getAttribute()方法
並且做用域範圍愈來愈大

 

1:request對象java

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

request對象封裝了瀏覽器的請求信息,經過request對象的各類方法能夠獲取客戶端以及用戶提交的各項請求信息。算法

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

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

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

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對象仍然有效
一、概念:Session表明服務器與瀏覽器的一次會話過程,這個過程是連續的,也能夠時斷時續的。在Servlet中,session指的是HttpSession類的對象,這個概念到此結束了,也許會很模糊,但只有看完本文,才能真正有個深入理解。
 
二、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的信息。
 
三、Session刪除的時間是:
1)Session超時:超時指的是連續必定時間服務器沒有收到該Session所對應客戶端的請求,而且這個時間超過了服務器設置的Session超時的最大時間。
2)程序調用HttpSession.invalidate()
3)服務器關閉或服務中止
 
四、session存放在哪裏:服務器端的內存中。不過session能夠經過特殊的方式作持久化管理。
 
五、session的id是從哪裏來的,sessionID是如何使用的:當客戶端第一次請求session對象時候,服務器會爲客戶端建立一個session,並將經過特殊算法算出一個session的ID,用來標識該session對象,當瀏覽器下次(session繼續有效時)請求別的資源的時候,瀏覽器會偷偷地將sessionID放置到請求頭中,服務器接收到請求後就獲得該請求的sessionID,服務器找到該id的session返還給請求者(Servlet)使用。一個會話只能有一個session對象,對session來講是隻認id不認人。
 
六、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);  
相關文章
相關標籤/搜索