JavaWeb之會話技術(shù)案例詳解
會話技術(shù)
1. 會話:一次會話中包含多次請求和響應(yīng)。
一次會話:瀏覽器第一次給服務(wù)器資源發(fā)送請求,會話建立,直到有一方斷開為止
2. 功能:在一次會話的范圍內(nèi)的多次請求間,共享數(shù)據(jù)
3. 方式:
1. 客戶端會話技術(shù):Cookie
2. 服務(wù)器端會話技術(shù):Session
Cookie:
1. 概念:客戶端會話技術(shù),將數(shù)據(jù)保存到客戶端
2. 快速入門:
1. 創(chuàng)建Cookie對象,綁定數(shù)據(jù)
new Cookie(String name, String value)
2. 發(fā)送Cookie對象
response.addCookie(Cookie cookie)
3. 獲取Cookie,拿到數(shù)據(jù)
Cookie[] request.getCookies()
3. 實(shí)現(xiàn)原理
基于響應(yīng)頭set-cookie和請求頭cookie實(shí)現(xiàn)
4.注意事項(xiàng):
1.一次可以發(fā)送多個cookie。可以創(chuàng)建多個Cookie對象,使用response調(diào)用多次addCookie方法發(fā)送cookie即可。
2. cookie在瀏覽器中保存的保存時間。使用setMaxAge(int seconds)方法可以將Cookie數(shù)據(jù)寫到硬盤的文件中,并指定cookie存活時間
3. 默認(rèn)情況下一個tomcat服務(wù)器中,部署了多個web項(xiàng)目,那么在這些web項(xiàng)目中cookie不能共享。如果要共享通過setPath(String path)設(shè)置當(dāng)前虛擬目錄:path設(shè)置為"/"
4. 不同的tomcat服務(wù)器間cookie共享問題?使用setDomain(String path)方法:如果設(shè)置一級域名相同,那么多個服務(wù)器之間cookie可以共享
5. Cookie的特點(diǎn)和作用
1. cookie存儲數(shù)據(jù)在客戶端瀏覽器
2. 瀏覽器對于單個cookie 的大小有限制(4kb) 以及 對同一個域名下的總cookie數(shù)量也有限制(20個)
a. cookie一般用于存出少量的不太敏感的數(shù)據(jù)
b. 在不登錄的情況下,完成服務(wù)器對客戶端的身份識別
代碼實(shí)現(xiàn)
//記錄電腦上次打開網(wǎng)頁的時間
@WebServlet("/CookieTest")
public class CookieTest extends HttpServlet {
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
//設(shè)置響應(yīng)體格式與編碼
resp.setContentType("text/html;charset=utf-8");
//獲取cookie
Cookie[] cookies = req.getCookies();
boolean flag=false;
//遍歷cookie數(shù)據(jù)
if (cookies!=null && cookies.length>0){
for (Cookie cookie : cookies) {
String name = cookie.getName();
//判斷名稱中是否有:lastTime
if ("lastTime".equals(name)){
//設(shè)置Cookie的value,下一次使用
flag=true;
Date date=new Date();
SimpleDateFormat sdf=new SimpleDateFormat("yyyy年MM月dd日 HH:mm:ss");
String str_date = sdf.format(date);
//tomcat不支持特殊字符,需要通過URL編碼
System.out.println("編碼前 "+str_date);
str_date=URLEncoder.encode(str_date,"utf-8");
System.out.println("編碼后"+str_date);
//新值串回去,設(shè)置存活時間
cookie.setValue(str_date);
cookie.setMaxAge(60*60*24);
resp.addCookie(cookie);
//有,歡迎光臨,上次登錄時間
String value = cookie.getValue();
//URL 解碼
value=URLDecoder.decode(value,"utf-8");
resp.getWriter().write("<h1>歡迎回來,您上一次的訪問時間是:"+value+"</h1>");
break;
}
}
}
if (cookies==null || cookies.length==0 || flag==false){
//第一次訪問
Date date=new Date();
SimpleDateFormat sdf=new SimpleDateFormat("yyyy年MM月dd日 HH:mm:ss");
String str_date = sdf.format(date);
//tomcat不支持特殊字符,需要通過URL編碼
System.out.println("編碼前 "+str_date);
str_date=URLEncoder.encode(str_date,"utf-8");
System.out.println("編碼后"+str_date);
Cookie cookie=new Cookie("lastTime",str_date);
//新值串回去,設(shè)置存活時間
cookie.setValue(str_date);
cookie.setMaxAge(60*60*24);
resp.addCookie(cookie);
resp.getWriter().write("<h1>您好,歡迎您首次訪問</h1>");
}
}
}
Session:
1. 概念:服務(wù)器端會話技術(shù),在一次會話的多次請求間共享數(shù)據(jù),將數(shù)據(jù)保存在服務(wù)器端的對象中。HttpSession
2. 快速入門:
1. 獲取HttpSession對象:
HttpSession session = request.getSession();
2. 使用HttpSession對象:
Object getAttribute(String name)
void setAttribute(String name, Object value)
void removeAttribute(String name)
3. 原理
Session的實(shí)現(xiàn)是依賴于Cookie的。
4. 細(xì)節(jié):
1. 當(dāng)客戶端關(guān)閉后,服務(wù)器不關(guān)閉,兩次獲取session是否為同一個?
默認(rèn)情況下。不是。
如果需要相同,則可以創(chuàng)建Cookie,鍵為JSESSIONID,設(shè)置最大存活時間,讓cookie持久化保存。
Cookie c = new Cookie("JSESSIONID",session.getId());
c.setMaxAge(60*60);
response.addCookie(c);
2. 客戶端不關(guān)閉,服務(wù)器關(guān)閉后,兩次獲取的session是同一個嗎?
不是同一個,但是要確保數(shù)據(jù)不丟失。tomcat自動完成以下工作
session的鈍化: 在服務(wù)器正常關(guān)閉之前,將session對象系列化到硬盤上
session的活化: 在服務(wù)器啟動后,將session文件轉(zhuǎn)化為內(nèi)存中的session對象即可。
3.session什么時候被銷毀?
1. 服務(wù)器關(guān)閉
2. session對象調(diào)用invalidate() 。
3. session默認(rèn)失效時間 30分鐘
5. session的特點(diǎn)
1. session用于存儲一次會話的多次請求的數(shù)據(jù),存在服務(wù)器端
2. session可以存儲任意類型,任意大小的數(shù)據(jù)
代碼實(shí)現(xiàn)
@WebServlet("/SessionDemo1")
public class SessionDemo1 extends HttpServlet {
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
//session
HttpSession session = request.getSession();
session.setAttribute("msg","hello session");
//請求轉(zhuǎn)發(fā)(這個是在一個URL中)
request.setAttribute("reqmsg","hello req.session");
request.getRequestDispatcher("/SessionDemo3").forward(request,response);
}
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
this.doPost(request,response);
}
}
@WebServlet("/SessionDemo3")
public class SessionDemo3 extends HttpServlet {
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
//獲取數(shù)據(jù)
HttpSession session = request.getSession();
Object msg = session.getAttribute("msg");
System.out.println(msg);
//請求轉(zhuǎn)發(fā)
Object reqmsg = request.getAttribute("reqmsg");
System.out.println(reqmsg);
}
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
this.doPost(request,response);
}
}
session與Cookie的區(qū)別:
1.session存儲數(shù)據(jù)在服務(wù)器端,Cookie在客戶端
2.session沒有數(shù)據(jù)大小限制,Cookie有
3.session數(shù)據(jù)安全,Cookie相對于不安全
4.session會在一定時間內(nèi)保存在服務(wù)器上。當(dāng)訪問增多,會比較占用你服務(wù)器的性能,考慮到減輕服務(wù)器性能方面,應(yīng)當(dāng)使用cookie。
到此這篇關(guān)于JavaWeb之會話技術(shù)案例詳解的文章就介紹到這了,更多相關(guān)JavaWeb之會話技術(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Spring定時任務(wù)關(guān)于@EnableScheduling的用法解析
這篇文章主要介紹了Spring定時任務(wù)關(guān)于@EnableScheduling的用法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-06-06
用Java設(shè)計實(shí)現(xiàn)多實(shí)例多庫查詢方式
這篇文章主要介紹了用Java設(shè)計實(shí)現(xiàn)多實(shí)例多庫查詢方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-03-03
基于Java實(shí)現(xiàn)的一層簡單人工神經(jīng)網(wǎng)絡(luò)算法示例
這篇文章主要介紹了基于Java實(shí)現(xiàn)的一層簡單人工神經(jīng)網(wǎng)絡(luò)算法,結(jié)合實(shí)例形式分析了java實(shí)現(xiàn)人工神經(jīng)網(wǎng)絡(luò)的具體實(shí)現(xiàn)技巧,需要的朋友可以參考下2017-12-12
基于Jenkins+Maven+Gitea+Nexus搭建CICD環(huán)境的方式
這篇文章主要介紹了基于Jenkins+Maven+Gitea+Nexus從0到1搭建CICD環(huán)境,大家都知道Nexus是一套“開箱即用”的系統(tǒng)不需要數(shù)據(jù)庫,它使用文件系統(tǒng)加Lucene來組織數(shù)據(jù),需要的朋友可以參考下2022-01-01

