標籤:col 使用 驗證 table name 日誌記錄 就是 日誌 映像
JSP 過濾器
Servlet和JSP中的過濾器都是Java類,它們存在的目的如下:
- 在請求訪問後端資源時攔截它
- 管理從伺服器返回給用戶端的響應
下面列出了多種常用的過濾器類型:
- 認證過濾器
- 資料壓縮過濾器
- 加密過濾器
- 觸發資源訪問事件的過濾器
- 映像轉換過濾器
- 登入和驗證過濾器
- MIME類型鏈過濾器
- 令牌過濾器
- 轉換XML內容的XSL/T過濾器
過濾器將會被插入進web.xml檔案中,然後映射servlet、JSP檔案的名字,或URL模式。部署描述檔案web.xml可以在 <Tomcat-installation-directory>\conf 目錄下找到。
當JSP容器啟動網路應用程式時,它會建立每一個過濾器的執行個體,這些過濾器必須在部署描述檔案web.xml中聲明,並且按聲明的順序執行。
Servlet過濾器方法
一個過濾器就是一個Java類,它實現了javax.servlet.Filter 介面。javax.servlet.Filter介面定義了三個方法:
序號 |
方法 &描述 |
1 |
public void doFilter (ServletRequest, ServletResponse, FilterChain) 每當 request/response要通過過濾鏈時容器會調用這個方法,因為用戶端請求鏈尾的資源 |
2 |
public void init(FilterConfig filterConfig) 容器調用這個方法來表明一個過濾器被安置在服務中 |
3 |
public void destroy() 容器調用這個方法來表明一個過濾器正在從服務中移除 |
JSP過濾器樣本
這個例子將會列印IP地址和每次訪問JSP檔案的日期時間。當然,這隻是個簡單的例子,讓您瞭解一些簡單的過濾器用法,但是可以使用這些概念來自行構造更複雜的程式。
// 引入Java包import java.io.*;import javax.servlet.*;import javax.servlet.http.*;import java.util.*; // 實現 Filter 類public class LogFilter implements Filter { public void init(FilterConfig config) throws ServletException{ // 擷取初始化參數 String testParam = config.getInitParameter("test-param"); //列印初始化參數 System.out.println("Test Param: " + testParam); } public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws java.io.IOException, ServletException { // 擷取用戶端ip地址 String ipAddress = request.getRemoteAddr(); // 輸出ip地址及目前時間 System.out.println("IP "+ ipAddress + ", Time " + new Date().toString()); // 傳遞請求道過濾器鏈 chain.doFilter(request,response); } public void destroy( ){ /* 在Filter執行個體在伺服器上被移除前調用。*/ }}
編譯LogFilter.java檔案,然後將編譯後的class檔案放在<Tomcat安裝目錄>/webapps/ROOT/WEB-INF/classes目錄下。
web.xml檔案中的JSP過濾器映射
過濾器被定義,然後映射成一個URL或JSP檔案名稱,與servlet被定義然後映射的方式差不多。在部署描述檔案web.xml中,使用<filter>標籤來進行過濾器映射:
<filter> <filter-name>LogFilter</filter-name> <filter-class>LogFilter</filter-class> <init-param> <param-name>test-param</param-name> <param-value>Initialization Paramter</param-value> </init-param></filter><filter-mapping> <filter-name>LogFilter</filter-name> <url-pattern>/*</url-pattern></filter-mapping>
上述過濾器將會應用在所有servlet和JSP程式中,因為我們在配置中指定了" /*"。您也可以指定一個servlet或JSP路徑,如果您只想要將過濾器應用在少數幾個servlet或JSP程式中的話。
現在,像平常一樣訪問servlet或JSP頁面,您就會探索服務器日誌中產生了關於此次訪問的記錄。您也可以使用Log4J記錄器來把日誌記錄在其它檔案中。
使用多重過濾器
您的網路應用程式可以定義很多不同的過濾器。現在,您定義了兩個過濾器,AuthenFilter和LogFilter,其它的步驟與前面講的一樣,除非要建立一個不同的映射,就像下面這樣:
<filter> <filter-name>LogFilter</filter-name> <filter-class>LogFilter</filter-class> <init-param> <param-name>test-param</param-name> <param-value>Initialization Paramter</param-value> </init-param></filter> <filter> <filter-name>AuthenFilter</filter-name> <filter-class>AuthenFilter</filter-class> <init-param> <param-name>test-param</param-name> <param-value>Initialization Paramter</param-value> </init-param></filter> <filter-mapping> <filter-name>LogFilter</filter-name> <url-pattern>/*</url-pattern></filter-mapping> <filter-mapping> <filter-name>AuthenFilter</filter-name> <url-pattern>/*</url-pattern></filter-mapping>
過濾器的應用順序
在web.xml中<filter>元素的映射順序決定了容器應用這些過濾器的順序。要反轉應用的順序,您只需要反轉web.xml中<filter>元素的定義順序就行了。
比如,上面的例子會首先應用 LogFilter然後再應用AuthenFilter,但是下面這個例子將會反轉應用的順序:
<filter-mapping> <filter-name>AuthenFilter</filter-name> <url-pattern>/*</url-pattern></filter-mapping> <filter-mapping> <filter-name>LogFilter</filter-name> <url-pattern>/*</url-pattern></filter-mapping>
Servlet和JSP中的過濾器都是Java類