編寫一個OnlineUserListener。
package anni; import java.util.List; import javax.servlet.ServletContext; import javax.servlet.http.HttpSession; import javax.servlet.http.HttpSessionListener; import javax.servlet.http.HttpSessionEvent; public class OnlineUserListener implements HttpSessionListener { public void sessionCreated(HttpSessionEvent event) { } public void sessionDestroyed(HttpSessionEvent event) { HttpSession session = event.getSession(); ServletContext application = session.getServletContext(); // 取得登錄的用戶名 String username = (String) session.getAttribute("username"); // 從在線列表中刪除用戶名 List onlineUserList = (List) application.getAttribute("onlineUserList"); onlineUserList.remove(username); System.out.println(username + "超時退出。"); } }
OnlineUserListener實現了HttpSessionListener定義的兩個方法:sessionCreated()和sessionDestroyed()。這兩個方法可以監聽到當前應用中session的創建和銷毀情況。我們這里只用到sessionDestroyed()在session銷毀時進行操作就可以。
從HttpSessionEvent中獲得即將銷毀的session,得到session中的用戶名,並從在線列表中刪除。最后一句向console打印一條信息,提示操作成功,這只是為了調試用,正常運行時刪除即可。
為了讓監聽器發揮作用,我們將它添加到web.xml中:
<listener> <listener-class>anni.OnlineUserListener</listener-class> </listener>
以下兩種情況下就會發生sessionDestoryed(會話銷毀)事件:
-
執行session.invalidate()方法時。
既然LogoutServlet.java中執行session.invalidate()時,會觸發sessionDestory()從在線用戶列表中清除當前用戶,我們就不必在LogoutServlet.java中對在線列表進行操作了,所以LogoutServlet.java的內容現在是這樣。
public void doGet(HttpServletRequest request,HttpServletResponse response) throwsServletException, IOException { // 銷毀 session request.getSession().invalidate(); // 成功 response.sendRedirect("index.jsp"); }
-
如果用戶長時間沒有訪問服務器,超過了會話最大超時時間,服務器就會自動銷毀超時的session。
會話超時時間可以在web.xml中進行設置,為了容易看到超時效果,我們將超時時間設置為最小值。
<session-config> <session-timeout>1</session-timeout> </session-config>
時間單位是一分鍾,並且只能是整數,如果是零或負數,那么會話就永遠不會超時。
對應例子在08-01,為了驗證OnlineUserListener是否能正常執行,我們可以登錄兩個用戶,其中一個點擊注銷,另一個等待一分鍾,然后可以在console中看到輸出的信息。