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屬性名(大寫))
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>
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獲得數據。
Session