1.過濾器html
Servlet中的過濾器Filter是實現了javax.servlet.Filter接口的服務器端程序,主要的用途是過濾字符編碼、作一些業務邏輯判斷等。其工做原理是,只要你在web.xml文件配置好要攔截的客戶端請求,它都會幫你攔截到請求,此時你就能夠對請求或響應(Request、Response)統一設置編碼,簡化操做;同時還可進行邏輯判斷,如用戶是否已經登錄、有沒有權限訪問該頁面等等工做。它是隨你的web應用啓動而啓動的,只初始化一次,之後就能夠攔截相關請求,只有當你的web應用中止或從新部署的時候才銷燬,如下經過過濾編碼的代碼示例來了解它的使用:java
[c-sharp] view plaincopymysql
MyCharsetFilter.java 編碼過濾器 web
package ...; spring
import ...; sql
// 主要目的:過濾字符編碼;其次,作一些應用邏輯判斷等. 數據庫
// Filter跟web應用一塊兒啓動 apache
// 當web應用從新啓動或銷燬時,Filter也被銷燬 編程
public class MyCharsetFilter implements Filter { 服務器
private FilterConfig config = null;
public void destroy() {
System.out.println("MyCharsetFilter準備銷燬...");
}
public void doFilter(ServletRequest arg0, ServletResponse arg1, FilterChain chain) throws IOException, ServletException {
// 強制類型轉換
HttpServletRequest request = (HttpServletRequest)arg0;
HttpServletResponse response = (HttpServletResponse)arg1;
// 獲取web.xm設置的編碼集,設置到Request、Response中 request.setCharacterEncoding(config.getInitParameter("charset")); response.setContentType(config.getInitParameter("contentType")); response.setCharacterEncoding(config.getInitParameter("charset"));
// 將請求轉發到目的地
chain.doFilter(request, response);
}
public void init(FilterConfig arg0) throws ServletException {
this.config = arg0;
System.out.println("MyCharsetFilter初始化...");
}
}
如下是 MyCharsetFilter.java 在web.xml 中配置:
[c-sharp] view plaincopy
<filter>
<filter-name>filter</filter-name>
<filter-class>dc.gz.filters.MyCharsetFilter</filter-class>
<init-param>
<param-name>charset</param-name>
<param-value>UTF-8</param-value>
</init-param>
<init-param>
<param-name>contentType</param-name>
<param-value>text/html;charset=UTF-8</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>filter</filter-name>
<!-- * 表明截獲全部的請求 或指定請求/test.do /xxx.do -->
<url-pattern>/*</url-pattern>
</filter-mapping>
以上的例子簡單的說明了Filter的使用,具體其餘的應用能夠看具體的場景。
2.監聽器
如今來講說Servlet的監聽器Listener,它是實現了javax.servlet.ServletContextListener 接口的服務器端程序,它也是隨web應用的啓動而啓動,只初始化一次,隨web應用的中止而銷燬。主要做用是: 作一些初始化的內容添加工做、設置一些基本的內容、好比一些參數或者是一些固定的對象等等。下面利用監聽器對數據庫鏈接池DataSource的初始化演示它的使用:
[c-sharp] view plaincopy
MyServletContextListener.java
package dc.gz.listeners;
import javax.servlet.ServletContext;
import javax.servlet.ServletContextEvent;
import javax.servlet.ServletContextListener;
import org.apache.commons.dbcp.BasicDataSource;
/**
* Web應用監聽器
*/
public class MyServletContextListener implements ServletContextListener {
// 應用監聽器的銷燬方法
public void contextDestroyed(ServletContextEvent event) {
ServletContext sc = event.getServletContext();
// 在整個web應用銷燬以前調用,將全部應用空間所設置的內容清空
sc.removeAttribute("dataSource");
System.out.println("銷燬工做完成...");
}
// 應用監聽器的初始化方法
public void contextInitialized(ServletContextEvent event) {
// 經過這個事件能夠獲取整個應用的空間
// 在整個web應用下面啓動的時候作一些初始化的內容添加工做
ServletContext sc = event.getServletContext();
// 設置一些基本的內容;好比一些參數或者是一些固定的對象
// 建立DataSource對象,鏈接池技術 dbcp
BasicDataSource bds = new BasicDataSource();
bds.setDriverClassName("com.mysql.jdbc.Driver"); bds.setUrl("jdbc:mysql://localhost:3306/hibernate");
bds.setUsername("root");
bds.setPassword("root");
bds.setMaxActive(10);//最大鏈接數
bds.setMaxIdle(5);//最大管理數
//bds.setMaxWait(maxWait); 最大等待時間
// 把 DataSource 放入ServletContext空間中,
// 供整個web應用的使用(獲取數據庫鏈接)
sc.setAttribute("dataSource", bds);
System.out.println("應用監聽器初始化工做完成...");
System.out.println("已經建立DataSource...");
}
}
web.xml中配置以下,很簡單:
[c-sharp] view plaincopy
<!-- 配置應用監聽器 -->
<listener>
<listener-class>dc.gz.listeners.MyServletContextListener</listener-class>
</listener>
這樣配置好了以後,之後在web應用中就能夠經過ServletContext取得BasicDataSource對象,從而獲取與數據庫的鏈接,提升性能,方便使用。
3.攔截器
攔截器是在面向切面編程中應用的,就是在你的service或者一個方法前調用一個方法,或者在方法後調用一個方法。是基於JAVA的反射機制。攔截器不是在web.xml,好比struts在struts.xml中配置,
[c-sharp] view plaincopy
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable
{
Object result = null;
System.out.println("before invoke method :" + method.getName());
result = method.invoke(this.targetObj, args);
System.out.println("after invoke method : " + method.getName());
return result;
}
總結:
1.過濾器:所謂過濾器顧名思義是用來過濾的,在java web中,你傳入的request,response提早過濾掉一些信息,或者提早設置一些參數,而後再傳入servlet或者struts的action進行業務邏輯,好比過濾掉非法url(不是login.do的地址請求,若是用戶沒有登錄都過濾掉),或者在傳入servlet或者struts的action前統一設置字符集,或者去除掉一些非法字符(聊天室常常用到的,一些罵人的話)。filter 流程是線性的, url傳來以後,檢查以後,可保持原來的流程繼續向下執行,被下一個filter, servlet接收等.
2.監聽器:這個東西在c/s模式裏面常常用到,他會對特定的事件產生產生一個處理。監聽在不少模式下用到。好比說觀察者模式,就是一個監聽來的。又好比struts能夠用監聽來啓動。Servlet監聽器用於監聽一些重要事件的發生,監聽器對象能夠在事情發生前、發生後能夠作一些必要的處理。
3.java的攔截器 主要是用在插件上,擴展件上好比 hivernate spring struts2等 有點相似面向切片的技術,在用以前先要在配置文件即xml文件裏聲明一段的那個東西。