麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學院 > 開發設計 > 正文

java學習筆記—會話2(26)

2019-11-14 23:39:22
字體:
來源:轉載
供稿:網友
java學習筆記—會話2(26)

1 使用Cookie實現顯示用戶的上次訪問時間

public void doGet(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException {         // 頁面輸出         response.setCharacterEncoding("utf-8");         response.setContentType("text/html;charset=utf-8");         request.setCharacterEncoding("utf-8");         // 獲取字符輸出流對象         PRintWriter out = response.getWriter();         // 獲取Cookie數組對象         Cookie [] cookies = request.getCookies();         // 定義一個時間的字符串變量         String date = null;         // 定義一個變量存儲系統當前日期         Date current_date = new Date();         SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");         // 判斷是否是第一次登陸         if(cookies != null){             // 直接循環             for(Cookie cookie : cookies){                 // 獲取Cookie                 if("lasttime".equals(cookie.getName())){                     // 獲取上次訪問的時間                     date = cookie.getValue();                      break;                 }else{                     // 獲取系統時間                     date = format.format(current_date);                 }             }         }else{             // 獲取系統時間             date = format.format(current_date);         }         // 顯示時間         out.println(date);         // 將這次訪問的時間寫入Cookie         Cookie new_cookie = new Cookie("lasttime",format.format(new Date()));          new_cookie.setMaxAge(5*60);         new_cookie.setPath("/day08/showtime");         // 發送         response.addCookie(new_cookie);    }
Cookie細節
  1. 一個Cookie只能存儲一種信息。
  2. 一個網站可以發送多個Cookie,瀏覽器可以同時攜帶多個Cookie。
  3. 同一個網站最多發送20個Cookie,瀏覽器最多存儲300個Cookie,一個Cookie最多存儲數據在4K以內。
  4. 如果創建了Cookie對象沒有指定最大有效時間那么不會存儲在瀏覽器的緩存中。
session技術

在上面使用Cookie技術存儲會話信息的時候發現Cookie存儲的數據有限,而且每次需要客戶端瀏覽器攜帶數據,導致網絡的負載過大。因此如果需要存儲相對大量的數據,那么可以直接將數據存儲在服務器端,這樣可以提高數據的訪問速度。

HttpSession技術就是將會話的數據存儲在服務器端,便于開發者直接進行訪問。

1 HttpSession接口

該接口主要定義了一種區分不同用戶并通過request對象獲取該對象的實例存儲與用戶相關的信息的方式。

該接口的對象是tomcat服務器幫助開發者創建出來的,當開發者調用request.getSession()方法獲取該接口的對象。

2 常用API

獲取HttpSession對象

HttpSession getSession()                 ? 如果有直接返回,如果沒有直接創建并返回HttpSession getSession(boolean create)        ? true同上,false有返回,沒有null

操作數據

void setAttribute(String name, Object value)     ? 設置指定名的屬性值 Object getAttribute(String name)                 ? 獲取指定名的屬性值Enumeration getAttributeNames()                ? 獲取所有屬性名的集合迭代器void removeAttribute(String name)            ? 刪除指定名的屬性

額外的方法

String getId()                             ? 獲取Session的ID值boolean isNew()                         ? 判斷Session是否是新的long getCreationTime()                     ? 獲取Session創建時間的longlong getLastaccessedTime()                 ? 獲取最后一次訪問Session的時間void invalidate()                        ? 指定Session無效

3 HttpSession的讀和寫

1. 寫Session數據

public void doGet(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException {       // 獲取session對象       HttpSession session = request.getSession();       // 放置數據       session.setAttribute("name", "jack");    }

發現響應信息中以Set-Cookie: JSESSIONID=8AA06CD311EC6A38805C73C93B8FCE4F; Path=/day08響應頭數據將HttpSession對象的ID值以Cookie的方式發送給瀏覽器進行存儲。

2. 讀Session數據

    public void doGet(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException {       // 獲取Session對象       HttpSession session = request.getSession();       // 取Session數據       String name = (String) session.getAttribute("name");       // 輸出信息       System.out.println(name);}

請求消息中使用Cookie: JSESSIONID=8AA06CD311EC6A38805C73C93B8FCE4F攜帶了HttpSession對象的ID值,那么服務器根據該值找到對應的HttpSession對象獲取其中的值。

總結:

HttpSession技術底層需要借助Cookie存儲服務器端為每一個用戶創建的HttpSession對象的ID值,便于后面拿到該值獲取服務器指定對象中值。

3 重新審視以上代碼

可以將獲取數據的servlet中的獲取sessiond的代碼修改如下

HttpSession session = request.getSession(false);

現在實際的瀏覽器在啟動多個同一個瀏覽器窗口,那么自動使用同一個Session對象。一旦Session的有效時間超過了半個小時那么Session自動銷毀。

4 其他的常用方法

public void doGet(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException {    // 獲取session對象    HttpSession session = request.getSession();    // 調用常用的方法    System.out.println("getId(): "+session.getId());    System.out.println("getLastAccessedTime(): "+session.getLastAccessedTime());    System.out.println("isNew(): "+session.isNew());    System.out.println("getCreationTime(): "+session.getCreationTime());}

運行結果

getId(): F8A7BC23A0B403CE30A69F8B5F903D6AgetLastAccessedTime(): 1358385915203isNew(): truegetCreationTime(): 1358385915203

如果在以上的代碼中使用了 session.invalidate();后繼續往session中添加數據,那么服務器報錯

java.lang.IllegalStateException: setAttribute: Session already invalidated

總結:

登陸功能分析à 1. 獲取用戶數據 2. 校驗數據 3. 成功,在Session中存儲用戶登陸的標識

注銷功能分析à 1. 清除Session中的用戶標識信息 2. 重定向到登陸頁面


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 欧美激情精品久久久久久黑人 | www.91操 | 久久久久久久久久久av | 一本色道久久综合狠狠躁篇适合什么人看 | 91 在线免费观看 | 可以看逼的视频 | 亚洲第一色片 | 性爱免费视频 | 97久久曰曰久久久 | 轻点插视频| 久久久久久久久久久一区 | 高潮激情aaaaa免费看 | 九九热视频在线 | 国产精品一区免费在线观看 | 免费黄网站在线播放 | 性明星video另类hd | 毛片免费一区二区三区 | 宅男噜噜噜66一区二区 | 国产午夜精品视频免费不卡69堂 | 中文字幕在线观看精品 | 18一20岁一级毛片 | 欧美日韩在线播放 | 日日狠狠久久 | 在线a免费观看 | 最新在线中文字幕 | 精品国产一区二区三 | 福利在线小视频 | av电影免费播放 | 一级免费观看 | 欧美性生活视频免费看 | 国产人成精品综合欧美成人 | 一本视频在线观看 | 看全色黄大色黄大片女图片 | 91在线色视频 | 91九色蝌蚪国产 | 视频一区二区三区视频 | 亚洲午夜影院在线观看 | 成人福利在线免费观看 | 男女牲高爱潮免费视频男女 | 欧美久久久一区二区三区 | 色综合精品|