HTTP是無狀態協議,這意味著每次客戶端檢索網頁時,都要單獨打開一個服務器連接,因此服務器不會記錄下先前客戶端請求的任何信息。
有三種方法來維持客戶端與服務器的會話:
網絡服務器可以指定一個唯一的 ID作為來代表每個客戶端,用來識別這個客戶端接下來的請求。
這可能不是一種有效的方式表單中的隱藏域控件是,因為很多時候瀏覽器并不一定支持,所以我們不建議使用這種方法來維持會話。
隱藏表單域
一個網絡服務器可以發送一個隱藏的HTML表單域和一個唯一的 ID,就像下面這樣:
sessionid" value="12345">
這個條目意味著,當表單被提交時,指定的名稱和值將會自動包含在GET或POST數據中。每當瀏覽器發送一個請求,的值就可以用來保存不同瀏覽器的軌跡。
這種方式可能是一種有效的方式,但點擊標簽中的超鏈接時不會產生表單提交事件,因此隱藏表單域也不支持通用會話跟蹤。
重寫URL
您可以在每個URL后面添加一些額外的數據來區分會話,服務器能夠根據這些數據來關聯標識符。
舉例來說,;=12345, 標識符為=12345,服務器可以用這個數據來識別客戶端。
相比而言,重寫URL是更好的方式來,就算瀏覽器不支持也能工作,但缺點是您必須為每個URL動態指定 ID,就算這是個簡單的HTML頁面。
對象
除了以上幾種方法外,JSP利用提供的接口來識別一個用戶,存儲這個用戶的所有訪問信息。
默認情況下,JSP允許會話跟蹤,一個新的對象將會自動地為新的客戶端實例化。禁止會話跟蹤需要顯式地關掉它,通過將page指令中屬性值設為false來實現,就像下面這樣:
<%@ page session="false" %>
JSP引擎將隱含的對象暴露給開發者。由于提供了對象,開發者就可以方便地存儲或檢索數據。
下表列出了對象的一些重要方法:
S.N.方法 & 描述
1
( name)返回對象中與指定名稱綁定的對象,如果不存在則返回null
2
()返回對象中所有的對象名稱
3
long ()返回對象被創建的時間,以毫秒為單位表單中的隱藏域控件是,從1970年1月1號凌晨開始算起
4
getId()返回對象的ID
5
long ()返回客戶端最后訪問的時間,以毫秒為單位,從1970年1月1號凌晨開始算起
6
int al()返回最大時間間隔,以秒為單位, 容器將會在這段時間內保持會話打開
7
void ()將無效化,解綁任何與該綁定的對象
8
isNew()返回是否為一個新的客戶端,或者客戶端是否拒絕加入
9
void ( name)移除中指定名稱的對象
10
void ( name, value) 使用指定的名稱和值來產生一個對象并綁定到中
11
void al(int )用來指定時間,以秒為單位,容器將會在這段時間內保持會話有效
JSP 應用
這個例子描述了如何使用對象來獲取創建時間和最后一次訪問時間。我們將會為對象關聯一個新的對象,如果這個對象尚未存在的話。
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%><%@ page import="java.io.*,java.util.*" %><% // 獲取session創建時間 Date createTime = new Date(session.getCreationTime()); // 獲取最后訪問頁面的時間 Date lastAccessTime = new Date(session.getLastAccessedTime()); String title = "再次訪問菜鳥教程實例"; Integer visitCount = new Integer(0); String visitCountKey = new String("visitCount"); String userIDKey = new String("userID"); String userID = new String("ABCD");// 檢測網頁是否由新的訪問用戶 if (session.isNew()){ title = "訪問菜鳥教程實例"; session.setAttribute(userIDKey, userID); session.setAttribute(visitCountKey, visitCount); } else { visitCount = (Integer)session.getAttribute(visitCountKey); visitCount += 1; userID = (String)session.getAttribute(userIDKey); session.setAttribute(visitCountKey, visitCount); }%>
Session 跟蹤 Session 跟蹤
Session 信息 | 值 |
---|---|
id | <% out.print( session.getId()); %> |
創建時間 | <% out.print(createTime); %> |
最后訪問時間 | <% out.print(lastAccessTime); %> |
用戶 ID | <% out.print(userID); %> |
訪問次數 | <% out.print(visitCount); %> |
試著訪問 :8080//main.jsp ,第一次運行時將會得到如下結果:
再次訪問,將會得到如下結果:
刪除數據
當處理完一個用戶的會話數據后,您可以有如下選擇:
15
超時以分鐘為單位,中的默認的超時時間是30分鐘。
中的al( ) 方法以秒為單位返回超時時間。如果在web.xml中配置的是15分鐘,則al( ) 方法將會返回900。