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ā)送多個(gè)cookie。可以創(chuàng)建多個(gè)Cookie對象,使用response調(diào)用多次addCookie方法發(fā)送cookie即可。
2. cookie在瀏覽器中保存的保存時(shí)間。使用setMaxAge(int seconds)方法可以將Cookie數(shù)據(jù)寫到硬盤的文件中,并指定cookie存活時(shí)間
3. 默認(rèn)情況下一個(gè)tomcat服務(wù)器中,部署了多個(gè)web項(xiàng)目,那么在這些web項(xiàng)目中cookie不能共享。如果要共享通過setPath(String path)設(shè)置當(dāng)前虛擬目錄:path設(shè)置為"/"
4. 不同的tomcat服務(wù)器間cookie共享問題?使用setDomain(String path)方法:如果設(shè)置一級域名相同,那么多個(gè)服務(wù)器之間cookie可以共享
5. Cookie的特點(diǎn)和作用
1. cookie存儲數(shù)據(jù)在客戶端瀏覽器
2. 瀏覽器對于單個(gè)cookie 的大小有限制(4kb) 以及 對同一個(gè)域名下的總cookie數(shù)量也有限制(20個(gè))
a. cookie一般用于存出少量的不太敏感的數(shù)據(jù)
b. 在不登錄的情況下,完成服務(wù)器對客戶端的身份識別
代碼實(shí)現(xiàn)
//記錄電腦上次打開網(wǎng)頁的時(shí)間 @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è)置存活時(shí)間 cookie.setValue(str_date); cookie.setMaxAge(60*60*24); resp.addCookie(cookie); //有,歡迎光臨,上次登錄時(shí)間 String value = cookie.getValue(); //URL 解碼 value=URLDecoder.decode(value,"utf-8"); resp.getWriter().write("<h1>歡迎回來,您上一次的訪問時(shí)間是:"+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è)置存活時(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是否為同一個(gè)?
默認(rèn)情況下。不是。
如果需要相同,則可以創(chuàng)建Cookie,鍵為JSESSIONID,設(shè)置最大存活時(shí)間,讓cookie持久化保存。
Cookie c = new Cookie("JSESSIONID",session.getId());
c.setMaxAge(60*60);
response.addCookie(c);
2. 客戶端不關(guān)閉,服務(wù)器關(guān)閉后,兩次獲取的session是同一個(gè)嗎?
不是同一個(gè),但是要確保數(shù)據(jù)不丟失。tomcat自動完成以下工作
session的鈍化: 在服務(wù)器正常關(guān)閉之前,將session對象系列化到硬盤上
session的活化: 在服務(wù)器啟動后,將session文件轉(zhuǎn)化為內(nèi)存中的session對象即可。
3.session什么時(shí)候被銷毀?
1. 服務(wù)器關(guān)閉
2. session對象調(diào)用invalidate() 。
3. session默認(rèn)失效時(shí)間 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ā)(這個(gè)是在一個(gè)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會在一定時(shí)間內(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)文章
Springboot整合freemarker 404問題解決方案
這篇文章主要介紹了Springboot整合freemarker 404問題解決方案,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-05-05金三銀四復(fù)工高頻面試題java算法LeetCode396旋轉(zhuǎn)函數(shù)
這篇文章主要為大家介紹了金三銀四復(fù)工高頻面試題之java算法題解LeetCode396旋轉(zhuǎn)函數(shù),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02JDBC獲取數(shù)據(jù)庫連接的5種方式實(shí)例
JDBC是一種用于執(zhí)行SQL語句的JavaAPI,為多種關(guān)系數(shù)據(jù)庫提供統(tǒng)一訪問,它由一組用Java語言編寫的類和接口組成,提供了諸如查詢和更新數(shù)據(jù)庫中數(shù)據(jù)的方法,這篇文章主要給大家介紹了關(guān)于JDBC獲取數(shù)據(jù)庫連接的5種方式,需要的朋友可以參考下2022-06-06java學(xué)習(xí)DongTai被動型IAST工具部署過程
被動型IAST被認(rèn)為是DevSecOps測試階段實(shí)現(xiàn)自動化安全測試的最佳工具,而就在前幾天,洞態(tài)IAST正式開源了,這對于甲方構(gòu)建安全工具鏈來說,絕對是一個(gè)大利好2021-10-10spring-shiro權(quán)限控制realm實(shí)戰(zhàn)教程
這篇文章主要介紹了spring-shiro權(quán)限控制realm實(shí)戰(zhàn)教程,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-10-10Java簡單實(shí)現(xiàn)SpringMVC+MyBatis分頁插件
自己最近搭建的一個(gè)SpringMVC+Mybatis的框架 屬于無實(shí)體類的框架 并實(shí)現(xiàn)了Myabtis的自動分頁和總數(shù)查詢 只要傳入分頁參數(shù)便能自動查詢總數(shù)和分頁 總數(shù)封裝在參數(shù)里面執(zhí)行查詢后可以直接從參數(shù)中獲取2015-09-09spring cloud eureka微服務(wù)之間的調(diào)用詳解
這篇文章主要介紹了spring cloud eureka微服務(wù)之間的調(diào)用詳解,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-07-07