Servlet中的過濾器(攔截器)Filter與監聽器Listener的做用和區別
Servlet中的過濾器Filter是實現了javax.servlet.Filter接口的服務器端程序,主要的用途是過濾字符編碼、作一些業務邏輯判斷等。其html
工做原理是,只要你在web.xml文件配置好要攔截的客戶端請求,它都會幫你攔截到請求,此時你就能夠對請求或響應(Request、 Response)統一設置編碼,簡化操做;同時還可進行邏輯判斷,如用戶是否已經登錄、有沒有權限訪問該頁面等等工做。它是隨你的web應用啓動而啓java
動的,只初始化一次,之後就能夠攔截相關請求,只有當你的web應用中止或從新部署的時候才銷燬,如下經過過濾編碼的代碼示例來了解mysql
它的使用:
1: MyCharsetFilter.java 編碼過濾器
2: package ...;
3: import ...;
4:
5: // 主要目的:過濾字符編碼;其次,作一些應用邏輯判斷等.
6: // Filter跟web應用一塊兒啓動
7: // 當web應用從新啓動或銷燬時,Filter也被銷燬
8: public class MyCharsetFilter implements Filter {
9: private FilterConfig config = null;
10:
11: public void destroy() {
12: System.out.println("MyCharsetFilter準備銷燬...");
13: }
14:
15: public void doFilter(ServletRequest arg0, ServletResponse arg1,
16: FilterChain chain) throws IOException, ServletException {
17: // 強制類型轉換
18: HttpServletRequest request = (HttpServletRequest)arg0;
19: HttpServletResponse response = (HttpServletResponse)arg1;
20: // 獲取web.xm設置的編碼集,設置到Request、Response中
21: request.setCharacterEncoding(config.getInitParameter("charset"));
22: response.setContentType(config.getInitParameter("contentType"));
23: response.setCharacterEncoding(config.getInitParameter("charset"));
24:
25: // 將請求轉發到目的地
26: chain.doFilter(request, response);
27: }
28:
29: public void init(FilterConfig arg0) throws ServletException {
30: this.config = arg0;
31: System.out.println("MyCharsetFilter初始化...");
32: }
33: }web
如下是 MyCharsetFilter.java 在web.xml 中配置:sql
1: <filter>
2: <filter-name>filter</filter-name>
3: <filter-class>dc.gz.filters.MyCharsetFilter</filter-class>
4: <init-param>
5: <param-name>charset</param-name>
6: <param-value>UTF-8</param-value>
7: </init-param>
8: <init-param>
9: <param-name>contentType</param-name>
10: <param-value>text/html;charset=UTF-8</param-value>
11: </init-param>
12: </filter>
13: <filter-mapping>
14: <filter-name>filter</filter-name>
15: <!-- * 表明截獲全部的請求 或指定請求/test.do /xxx.do -->
16: <url-pattern>/*</url-pattern>
17: </filter-mapping>數據庫
以上的例子簡單的說明了Filter的使用,具體其餘的應用能夠看具體的場景。apache
如今來講說Servlet的監聽器Listener,它是實現了javax.servlet.ServletContextListener 接口的服務器端程序,它也是隨web應用的啓服務器
動而啓動,只初始化一次,隨web應用的中止而銷燬。主要做用是: 作一些初始化的內容添加工做、設置一些基本的內容、好比一些參數或app
者是一些固定的對象等等。下面利用監聽器對數據庫鏈接池DataSource的初始化演示它的使用:
1: MyServletContextListener.java
2: package dc.gz.listeners;
3: import javax.servlet.ServletContext;
4: import javax.servlet.ServletContextEvent;
5: import javax.servlet.ServletContextListener;
6: import org.apache.commons.dbcp.BasicDataSource;
7:
8: /**
9: * Web應用監聽器
10: */
11: public class MyServletContextListener implements ServletContextListener {
12:
13: // 應用監聽器的銷燬方法
14: public void contextDestroyed(ServletContextEvent event) {
15: ServletContext sc = event.getServletContext();
16: // 在整個web應用銷燬以前調用,將全部應用空間所設置的內容清空
17: sc.removeAttribute("dataSource");
18: System.out.println("銷燬工做完成...");
19: }
20:
21: // 應用監聽器的初始化方法
22: public void contextInitialized(ServletContextEvent event) {
23: // 經過這個事件能夠獲取整個應用的空間
24: // 在整個web應用下面啓動的時候作一些初始化的內容添加工做
25: ServletContext sc = event.getServletContext();
26: // 設置一些基本的內容;好比一些參數或者是一些固定的對象
27: // 建立DataSource對象,鏈接池技術 dbcp
28: BasicDataSource bds = new BasicDataSource();
29: bds.setDriverClassName("com.mysql.jdbc.Driver");
30: bds.setUrl("jdbc:mysql://localhost:3306/hibernate");
31: bds.setUsername("root");
32: bds.setPassword("root");
33: bds.setMaxActive(10);//最大鏈接數
34: bds.setMaxIdle(5);//最大管理數
35: //bds.setMaxWait(maxWait); 最大等待時間
36: // 把 DataSource 放入ServletContext空間中,
37: // 供整個web應用的使用(獲取數據庫鏈接)
38: sc.setAttribute("dataSource", bds);
39: System.out.println("應用監聽器初始化工做完成...");
40: System.out.println("已經建立DataSource...");
41: }
42: }性能
web.xml中配置以下,很簡單:
1: <!-- 配置應用監聽器 -->
2: <listener>
3: <listener-class>dc.gz.listeners.MyServletContextListener</listener-class>
4: </listener>
這樣配置好了以後,之後在web應用中就能夠經過ServletContext取得BasicDataSource對象,從而獲取與數據庫的鏈接,提升性能,方便使
用。
上面經過兩個示例演示了Filter和Listener的基本使用,對於其它的應用則須要咱們在項目開發中根據具體的場景選擇。