一、表單提交方式之Get和Post的區(qū)別
Get:以明文的方式通過(guò)URL提交數(shù)據(jù),數(shù)據(jù)在URL中可以看到。提交的數(shù)據(jù)最多不超過(guò)2KB,安全性較低但效率比Post方式高。適合提交數(shù)據(jù)量不大,安全性不高的數(shù)據(jù)。比如:搜索、查詢等功能。
Post:將用戶提交的信息封裝在HTML HEADER內(nèi)。適合提交數(shù)據(jù)量大,安全性高的用戶信息。比如:注冊(cè)、登錄、修改、上傳等功能。
二、Jsp內(nèi)置對(duì)象
1、Request對(duì)象
request對(duì)象封裝了客戶端的請(qǐng)求信息,通過(guò)它才能了解到客戶的需求,然后做出響應(yīng),request對(duì)象具有請(qǐng)求域,即完成客戶端的請(qǐng)求之前,該對(duì)象一直有效,是HttpServletRequest的實(shí)例對(duì)象,常用方法如下:
String getParameter(String name):返回name指定參數(shù)的參數(shù)值,常用于獲取頁(yè)面提交的數(shù)據(jù)
String[] getParameterValues(String name) :返回所有包含參數(shù)name的數(shù)組
void setAttribute(String,Object):存儲(chǔ)此請(qǐng)求中的屬性,常用于請(qǐng)求轉(zhuǎn)發(fā)時(shí)給下個(gè)頁(yè)面?zhèn)鬟f數(shù)據(jù)
object getAttribute(String name):返回name指定的屬性值,常用于獲取RequestScode的屬性
String getContentType():返回請(qǐng)求體的MIME類型
String getProtocol():返回請(qǐng)求用的協(xié)議類型及版本號(hào)
String getServerName():返回接收請(qǐng)求的服務(wù)器主機(jī)名
2、Response對(duì)象
response對(duì)象包含了響應(yīng)客戶請(qǐng)求的有關(guān)信息,但在Jsp中很少直接用到它,它的對(duì)象具有頁(yè)面作用域,即訪問(wèn)一個(gè)頁(yè)面時(shí),該頁(yè)面內(nèi)的response對(duì)象只能對(duì)這次訪問(wèn)有效,其它頁(yè)面的response對(duì)象對(duì)當(dāng)前頁(yè)面無(wú)效,是HttpServletResponse的實(shí)例對(duì)象,常用方法如下:
String getCharacterEncoding():返回響應(yīng)用的字符編碼格式
void setContentType(String type):設(shè)置相應(yīng)的MIME類型
PrintWriter getWriter():返回一個(gè)可以向客戶端輸出字符的對(duì)象,注意:getWriter()獲得的對(duì)象輸出內(nèi)容會(huì)提前于內(nèi)置對(duì)象out輸出內(nèi)容。解決:調(diào)用out.flush();
sendRedirect(String location):重新定向客戶端的請(qǐng)求
3、Session對(duì)象
session對(duì)象在第一個(gè)Jsp頁(yè)面被裝載時(shí)自動(dòng)創(chuàng)建,完成會(huì)話期管理,從一個(gè)客戶打開(kāi)瀏覽器并連接到服務(wù)器開(kāi)始,到客戶關(guān)閉瀏覽器離開(kāi)這個(gè)服務(wù)器結(jié)束,被稱為一個(gè)會(huì)話,當(dāng)一個(gè)客戶訪問(wèn)一個(gè)服務(wù)器時(shí),可能會(huì)在服務(wù)器的幾個(gè)頁(yè)面之間切換,服務(wù)器通過(guò)session對(duì)象可知這幾個(gè)頁(yè)面是同一個(gè)客戶操作,服務(wù)器的內(nèi)存中保存著不同用戶的session,是HttpSession的實(shí)例對(duì)象,在HttpServerletRequest中獲取,常用方法如下:
long getCreateTime():返回SESSION創(chuàng)建時(shí)間
String getId():返回SESSION創(chuàng)建時(shí)Jsp引擎為它設(shè)置的唯一標(biāo)識(shí)
Object setAttribute(String name,Object value):用指定名稱將對(duì)象綁定到此會(huì)話
Object getAttribute(String name):返回指定名稱綁定的對(duì)象,如不存在,返回null
String[] getValueNames():返回一個(gè)包含此SESSION所有可用數(shù)據(jù)的集合
int getMaxInactiveInterval():返回SESSION在兩次請(qǐng)求之間的最大存活時(shí)間,單位秒
Session的生命周期:創(chuàng)建、活動(dòng)、銷毀。
Session的銷毀方式(3種):session.invalidate();session超時(shí);服務(wù)器重啟;
服務(wù)器如何判斷多個(gè)頁(yè)面是同一個(gè)會(huì)話:在Session被創(chuàng)建時(shí),服務(wù)器會(huì)為Session對(duì)象指定一個(gè)唯一的標(biāo)識(shí)ID,當(dāng)客戶端后續(xù)訪問(wèn)服務(wù)器時(shí),Session對(duì)象都會(huì)把這個(gè)標(biāo)識(shí)ID傳給服務(wù)器,這樣服務(wù)器就能識(shí)別出訪問(wèn)當(dāng)前頁(yè)面的是哪一個(gè)會(huì)話了。同一個(gè)Session對(duì)象的生命周期為打開(kāi)瀏覽器開(kāi)始,直到關(guān)閉瀏覽器結(jié)束。
Session的使用場(chǎng)景:保存登錄驗(yàn)證碼圖片的文字、保存登錄前的訪問(wèn)路徑(如在商城中瀏覽商品無(wú)須登錄,當(dāng)購(gòu)買商品時(shí),需要進(jìn)行用戶登錄,此時(shí)就需要保存當(dāng)前訪問(wèn)的路徑,直到登錄成功后,從Session中將路徑取出,這里保存的是相對(duì)路徑,即經(jīng)過(guò)控制器攔截處理的路徑)。
注意:當(dāng)所有頁(yè)面關(guān)閉后,重新打開(kāi)一個(gè)新的頁(yè)面,Session對(duì)象雖然會(huì)重新創(chuàng)建,但原有的Session不會(huì)被銷毀,這個(gè)舊的Session對(duì)象仍存在于服務(wù)器端,只不過(guò)再無(wú)客戶端攜帶它與服務(wù)器校驗(yàn),直到Session超時(shí),這個(gè)Session對(duì)象才被銷毀,Tomcat默認(rèn)的Session超時(shí)時(shí)間為30分鐘,我們可以通過(guò)session.setMaxInactiveInterval(時(shí)間/秒),也可在xml中配置<session-timeout>節(jié)點(diǎn)。
4、Out對(duì)象
out對(duì)象常用于向客戶端輸出內(nèi)容。
void println():向客戶端打印字符串
void clear():清除緩沖區(qū)的內(nèi)容,如果在flush()方法后調(diào)用會(huì)拋出異常
void clearBuffer():清除緩沖區(qū)的內(nèi)容,在flush()方法后調(diào)用不會(huì)拋出異常
void flush():將緩沖區(qū)內(nèi)容輸出到客戶端
int getBufferSize():返回緩沖區(qū)字節(jié)數(shù)的大小,如不設(shè)緩沖區(qū),則大小為0
int getRemaining():返回緩沖區(qū)剩余可用的空間大小
boolean isAutoFlush():返回緩沖區(qū)滿時(shí),是自動(dòng)清空還是拋出異常
void close():關(guān)閉輸出流
5、Application對(duì)象
application對(duì)象實(shí)現(xiàn)了用戶間數(shù)據(jù)的共享,可存放全局變量,它開(kāi)始于服務(wù)器的啟動(dòng),終止于服務(wù)器的關(guān)閉,在用戶的前后連接或不同用戶之間的連接中,可以對(duì)application對(duì)象的同一屬性操作,在任何地方對(duì)application對(duì)象屬性的操作,都將影響到其他用戶對(duì)此的訪問(wèn),服務(wù)器的啟動(dòng)和關(guān)閉決定了application對(duì)象的生命,它是ServletContext類的實(shí)例,常用方法如下:
void setAttribute(String name,Object value):使用指定名稱將對(duì)象綁定
Object getAttribute(String name):返回指定名稱綁定的對(duì)象,如無(wú)綁定,返回null
Enumeration getAttributeNames():返回所有可用屬性名的枚舉
String getServerInfo():返回Jsp(Servlet)引擎名和版本號(hào)
6、Page對(duì)象
page對(duì)象就是指向當(dāng)前Jsp頁(yè)面本身,有點(diǎn)像類中的this指針,它是Java.lang.Object類的實(shí)例,常用方法如下:
class getClass():返回此Object的類
int hashCode():返回此Object的hash碼
boolean equals(Object obj):判斷此Object是否與指定的Object對(duì)象相等
void copy(Object obj):把此Object拷貝到指定的obj對(duì)象中
Object clone():克隆此Object對(duì)象
String toString():把此Object對(duì)象轉(zhuǎn)換成String類的對(duì)象
void notify():?jiǎn)拘岩粋€(gè)等待的線程
void notifyAll():?jiǎn)拘阉械却木€程
void wait(int timeout):使一個(gè)線程處于等待狀態(tài)知道timeout結(jié)束或被喚醒
void wait():使一個(gè)線程處于等待直到被喚醒
7、PageContext對(duì)象
pageContext對(duì)象提供了對(duì)Jsp頁(yè)面內(nèi)所有的對(duì)象及名字空間的使用,它可以訪問(wèn)到本頁(yè)所在的session,也可以取得本頁(yè)面所在的application的某一屬性值,它相當(dāng)于頁(yè)面中所有功能的集成者,它本類名也是pageContext,常用方法如下:
JspWriter getOut():返回當(dāng)前客戶端響應(yīng)被使用的JspWriter流(out)
HttpSession getSession():返回當(dāng)前頁(yè)中的HttpSession對(duì)象
Object getPage():返回當(dāng)前頁(yè)的Object對(duì)象(page)
ServletRequest getRequest():返回當(dāng)前頁(yè)的ServletRequest對(duì)象
ServletResponse getResponse():返回當(dāng)前頁(yè)的ServletResponse對(duì)象
void setAttribute(String name,Object attr):設(shè)置屬性和屬性值
Object getAttribute(String name,int scope):指定范圍內(nèi)取出屬性值
int getAttributeScope(String name):返回某屬性的作用范圍
void forward(String relativeUrlPath):使當(dāng)前頁(yè)面重導(dǎo)到另一頁(yè)面
void include(String relativeUrlPath):在當(dāng)前位置包含另一文件
8、Config對(duì)象
config對(duì)象是在一個(gè)Servlet初始化時(shí),Jsp引擎向它傳遞信息用的,此信息包括Servlet初始化時(shí)所要用到的參數(shù)(屬性名和屬性值構(gòu)成)以及服務(wù)器的有關(guān)信息(傳遞一個(gè)ServletContext對(duì)象),常用方法如下:
ServletContext getServletContext():返回含有服務(wù)器相關(guān)信息的ServletContext對(duì)象
String getInitParameter(String name):返回初始化參數(shù)的值
Enumeration getInitParameterNames():返回Servlet初始化所需所有參數(shù)的枚舉
9、exception對(duì)象
exception對(duì)象是一個(gè)異常對(duì)象,當(dāng)一個(gè)頁(yè)面在運(yùn)行過(guò)程中發(fā)生了異常,就產(chǎn)生這個(gè)對(duì)象,如果一個(gè)Jsp頁(yè)面要應(yīng)用此對(duì)象,就必須把isErrorPage設(shè)為true,否則無(wú)法編譯,它是Java.lang.Throwable的實(shí)例,常用方法如下:
String getMessage():返回描述異常的消息
String toString():返回關(guān)于異常的簡(jiǎn)短描述信息
void printStackTrace():顯示異常及其棧軌跡
Throwable FillInStackTrace():重寫(xiě)異常的執(zhí)行棧軌跡
捕捉頁(yè)面使用:errorPage="異常捕捉交給誰(shuí)處理"?
處理頁(yè)面使用 :isErrorPage="是否應(yīng)用exception對(duì)象"
三、請(qǐng)求轉(zhuǎn)發(fā)與請(qǐng)求重定向
請(qǐng)求重定向:客戶端行為,本質(zhì)等于兩次請(qǐng)求,第一次請(qǐng)求對(duì)象不保存,URL地址會(huì)改變
通過(guò)HttpServerletResponse對(duì)象:response.sendRedirect("/login.html");
通過(guò)Controller返回類型:return "redirect:/login.html";
通過(guò)Jsp指令:<c:redirect url="/login.html"/>
例子:你去A局辦事,A局的人告訴你這事屬于B局管,然后你走出A局,自己乘車去了B局。
請(qǐng)求轉(zhuǎn)發(fā) :服務(wù)器行為,是一次請(qǐng)求,轉(zhuǎn)發(fā)后請(qǐng)求對(duì)象會(huì)保存,地址欄的URL地址不會(huì)改變
通過(guò)HttpServerletRequest對(duì)象:request.getRequestDispatcher("/login.html").forward(req,resp);
通過(guò)Controller返回類型:return "forward:/login.html";
通過(guò)Jsp指令:<jsp:forward page="login.html">
例子:你去A局辦事,A局知道這事屬于B局管,它并沒(méi)有拒絕你的請(qǐng)求,而是幫你聯(lián)系B局辦事。
四、JavaBean的使用
1、Javabean的設(shè)計(jì)原則
共有類、無(wú)參的共有構(gòu)造方法、屬性私有、getter()和setter()方法
2、Jsp動(dòng)作
Jsp動(dòng)作元素為請(qǐng)求處理階段提供信息,動(dòng)作元素遵循XML元素的語(yǔ)法,有一個(gè)包含元素名的開(kāi)始標(biāo)簽,可以有屬性,可選的內(nèi)容、與開(kāi)始標(biāo)簽匹配的結(jié)束標(biāo)簽。
3、Jsp中使用Javabean的兩種方式
像Java類一樣,直接創(chuàng)建實(shí)例
<% ?Manager manager =new Manager(); ?%>
Jsp動(dòng)作標(biāo)簽里使用Javabean
<jsp:useBeanid="manager"? scope="page" class="jspUseBean.Manager">
scope是作用域范圍,id是唯一標(biāo)識(shí),class是Javabean的全類名(包名+類名)
4、給已實(shí)例化的Javabean對(duì)象屬性賦值的四種方式
name的屬性是useBean的id,property的值是所匹配的javabean的屬性,從表單獲取,value的值是手動(dòng)為javabean設(shè)置屬性,params的值是從request對(duì)象的參數(shù)獲取,request參數(shù)的賦值方法,如:<form action="java.jsp?wjx="wjx"/>
<jsp:setProperty property=" * " name="manager"/> ??
<jsp:setProperty property="username" name="manager" ?/>
<jsp:setProperty?property="username" name="manager" value="wjx" />
<jsp:setProperty?property="username" name="manager" params="wjx" />
5、獲取Javabean對(duì)象屬性的值
<jsp:getProperty?property="username" name="manager" value="wjx" />
6、Javabean的4個(gè)作用域范圍,可用userBean的scope屬性來(lái)設(shè)置范圍
page: 僅在當(dāng)前頁(yè)面有效
request:請(qǐng)求范圍,可以通過(guò)HttpRequest.getAttribute()方法獲取Javabean對(duì)象,
session:會(huì)話范圍,可以通過(guò)HttpSession.getAttribute()方法獲取Javabean對(duì)象
application:全局范圍,可以通過(guò)application.getAttribute(0方法獲取Javabean對(duì)象
五、Cookie對(duì)象
Cookie是Web服務(wù)器保存在客戶端的一系列的文本信息,典型應(yīng)用:判斷注冊(cè)用戶是否已經(jīng)登錄網(wǎng)站,購(gòu)物車的處理等。作用:對(duì)特定對(duì)象的追蹤,保存用戶網(wǎng)頁(yè)瀏覽記錄與習(xí)慣,簡(jiǎn)化登錄,弊端是容易泄漏用戶信息,常用方法如下:
void setmaxAge(int expiry):設(shè)置cookie有效期,單位秒
int getMaxAge():獲取cookie對(duì)象的有效時(shí)長(zhǎng),單位秒
void setValue(String value):對(duì)cookie對(duì)象進(jìn)行賦值
String getValue():獲取cookie的值
String getName():獲取cookie的名稱
void setPath("/"); 設(shè)置共享路徑
完整的創(chuàng)建過(guò)程:
Cookie cookie = new Cookie("userId", String.valueOf(user.getId()));
cookie.setMaxAge(60 * 60 * 24 * 30);
cookie.setPath("/");
response.addCookie(cookie);
使用場(chǎng)景:商城的購(gòu)物車(購(gòu)物車的內(nèi)容是一個(gè)Json數(shù)組,轉(zhuǎn)換成Java即是一個(gè)List)、用戶的登錄狀態(tài)(用戶的唯一標(biāo)識(shí)可以存放在瀏覽器中)
六、Cookie和Session對(duì)比
七、Jsp指令和動(dòng)作元素
1、include動(dòng)作(動(dòng)態(tài)引入,不能獲取jsp頁(yè)面數(shù)據(jù))
<jsp: include page="../include/header.jsp" flush="true|false" />
page 指要包含的頁(yè)面 , flush 指被包含的頁(yè)面是否從緩沖區(qū)讀取
2、forward動(dòng)作
<jsp:forward page="url" /> ?等價(jià) request.getRequestDispatcher("url").forward(req,resp);
3、param動(dòng)作
<jsp:param name="參數(shù)名" value="參數(shù)值">
常常與<jsp:forward>一起使用,作為其的子標(biāo)簽
4、include指令(靜態(tài)引入,能獲取jsp頁(yè)面數(shù)據(jù))
<%@ include file="/WEB-INF/include/taglib.jsp" %>
5、指令和動(dòng)作比較
八、中文亂碼
1、URL傳中文參數(shù)出現(xiàn)亂碼
例子:<a href="request.jsp?username=老吳">URL傳中文參數(shù)</a>
解決:選擇Tomcat目錄下的Server.xml,找到Connector字段,Connector里面是默認(rèn)端口號(hào)以及其他配置信息,再往里添加URIEncoding="utf-8"字段,然后重啟Tomcat服務(wù)器。注:在代碼中使用request.setCharacterEncoding("utf-8");不能解決URL傳中文亂碼的問(wèn)題。
URI和URL的區(qū)別:URL是絕對(duì)路徑,URI是相對(duì)路徑。
2、表單傳中文參數(shù)出現(xiàn)亂碼
例子:<%=request.getParameter("username")%> (接收表單頁(yè)面的代碼)
原因:Tomcat在提交表單時(shí)默認(rèn)的編碼格式是ISO-8859-1,我們需要的是utf-8。
解決:在例子代碼執(zhí)行前設(shè)置Tomcat的編碼格式,request.setCharacterEncoding("utf-8");
3、中文信息保存在cookie對(duì)象中,先轉(zhuǎn)碼再保存,獲取后再解碼。
import Java.net.*; ?
request.setCharacterEncoding("utf-8");
轉(zhuǎn)碼:String username =URLEncoder.encode(request.getParameter("username"),"utf-8");
解碼:username =URLDecoder.decode(cookie.getValue(),"utf-8");
4、Jsp文件里寫(xiě)中文后不能保存代碼
原因:Jsp文件的編碼格式是ISO-8859-1。
解決:把所有的編碼格式都改為utf-8。