JSP Session處理 (轉)
員經常要在global.asa內處理Application_start,Session_Start等
事件,如:驗證、重定向不同編碼頁面等,十分方便,然而一向頗受歡迎的並不很支援這種處理,除了商業化JRun支援global.jsa以外,竟連應用率極高的開放原始碼伺服器都不支援,這給JSP的開發造成不小障礙,雖然早期Tomcat(5.0以前版本)下可以透過以下方式實現Session-start事件處理
1. 新增Session
session.put(“bind.listener”,new MyListener(getContext())
2. 定義MyListener類
import x.servlet.http.*;
import javax.servlet.*;
public class MyListener implements HttpSessionBindingListener
{
ServletContext context;
public ODSessionListener(ServletContext context)
{
this.context=context;
}
public void valueBound(HttpSessionBindingEvent event)
{
System.out.println(“bound”);
}
public void valueUnBound(HttpSessionBindingEvent event)
{
System.out.println(“unbound”);
}
}
:namespace prefix = o ns = "urn:schemas--com::office" />
但處理前提是Session已經建立,並且不能在Session建立時處理驗證等事件,透過研究Servlet 2.4(Tomcat5.0內建)終於找到一種可行方法,實現方法如下:
//---------------------- SessionListener.java----------------------------------------------------
package listeners;
import javax.servlet.ServletContext;
import javax.servlet.ServletContextEvent;
import javax.servlet.ServletContextListener;
import javax.servlet.http.HttpSessionAttributeListener;
import javax.servlet.http.HttpSessionBindingEvent;
import javax.servlet.http.HttpSessionEvent;
import javax.servlet.http.HttpSessionListener;
// ServletRequestListener為Servlet2.4新增介面
import javax.servlet.ServletRequestListener;
import javax.servlet.ServletRequestEvent;
import javax.servlet.http.HttpServletRequest;
public final class SessionListener
implements HttpSessionListener,ServletRequestListener {
private HttpServletRequest request;
public void requestDestroyed(ServletRequestEvent sre) { }
public void requestInitialized(ServletRequestEvent sre)
{
request=(HttpServletRequest)sre.getServletRequest();
}
public void sessionCreated(HttpSessionEvent event) {
String logMsg=event.getSession().getId()
+"' '"+request.getRemoteAddr()
+":"+request.getRemotePort();
log("sessionCreated('" + logMsg + "')");
}
public void sessionDestroyed(HttpSessionEvent event) {
log("sessionDestroyed('" + event.getSession().getId() + "')");
}
private void log(String message) {
System.out.println("SessionListener: " + message);
}
}
在開始接到客戶端請求(requestInitialized)時,獲得當前的HttpRequest儲存在私有成員 request 中,這樣在Session建立時可以實現對Session使用者進行驗證,以及關閉Session,限制訪問等,這裡僅以記錄Session來源為例(SessionListener.java)
編譯這個類後還要在.xml的host元素內加入以下行:
本文適用環境:Tomcat 5.02,1.41(不支援商業伺服器)
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/10752043/viewspace-956684/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 處理JSP中的中文 (轉)JS
- JSP 異常處理如何處理?JS
- 輕鬆實現session的mysql處理 (轉)SessionMySql
- JSP 日期處理概述JS
- JSP(12) - 商品處理模組JS
- ThinkPHP 3.2 中 session 的處理PHPSession
- 處理Oracle Session中的鎖OracleSession
- jsp:useBean的亂碼處理JSBean
- JSP筆記-sessionJS筆記Session
- Cookie&Session&JSPCookieSessionJS
- Nginx和Tomcat的session處理NginxTomcatSession
- Oracle plsql session間通訊處理OracleSQLSession
- JSP筆記-XML 資料處理JS筆記XML
- JSP內建物件——sessionJS物件Session
- Spring Boot 2 + Redis 處理 Session 共享Spring BootRedisSession
- JSP中Beans 與 Forms處理機制JSBeanORM
- 許可權處理 - 用redis實現分散式session~ (cookie && session )Redis分散式SessionCookie
- Jsp/Servlet接收FORM表格引數時輸出亂碼的處理 (轉)JSServletORM
- Asp.Net處理Session失效解決方案ASP.NETSession
- 深入剖析JSP和Servlet對中文的處理JSServlet
- 請教JSP/servlet容器對更新的JSP頁面處理的原理JSServlet
- windows下處理kill session不被釋放的鎖WindowsSession
- asp.net 一般處理程式接收SessionASP.NETSession
- 異常處理 (轉)
- spring security:ajax請求的session超時處理SpringSession
- 一次WRH$_ACTIVE_SESSION_HISTORY問題處理Session
- JSP九大內建物件 sessionJS物件Session
- Java學習-jsp內建物件SessionJavaJS物件Session
- (轉)機器學習:偏差處理(2)機器學習
- 海量資料處理 (轉)
- 異常處理方法 (轉)
- 【轉】Oracle 異常處理Oracle
- mysql事務處理(轉)MySql
- [Oracle報錯處理]ORA-00031: session marked for killOracleSession
- 使用R和Apache Spark處理大規模資料 [session]ApacheSparkSession
- Nginx和Tomcat的session處理分為兩步 2NginxTomcatSession
- 資料處理及跳轉
- 【轉載】SHELL字串處理技巧(${}、##、%%)字串