1.过滤器
Servlet中的过滤器Filter是实现了javax.servlet.Filter接口的服务器端程序,主要的用途是过滤字符编码、做一些业务逻辑判断等。其工作原理是,只要你在web.xml文件配置好要拦截的客户端请求,它都会帮你拦截到请求,此时你就可以对请求或响应(Request、Response)统一设置编码,简化操作;同时还可进行逻辑判断,如用户是否已经登陆、有没有权限访问该页面等等工作。它是随你的web应用启动而启动的,只初始化一次,以后就可以拦截相关请求,只有当你的web应用停止或重新部署的时候才销毁,以下通过过滤编码的代码示例来了解它的使用:
[c-sharp] view plain copy
- MyCharsetFilter.<a href="http://lib.csdn.net/base/javaee" class='replace_word' title="Java EE知识库" target='_blank' style='color:#df3434; font-weight:bold;'>Java</a> 编码过滤器
- package ...;
- import ...;
-
-
-
- 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;
-
-
- 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 plain copy
- <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 plain copy
- MyServletContextListener.java
- package dc.gz.listeners;
- import javax.servlet.ServletContext;
- import javax.servlet.ServletContextEvent;
- import javax.servlet.ServletContextListener;
- import org.apache.commons.dbcp.BasicDataSource;
-
-
-
-
- public class MyServletContextListener implements ServletContextListener {
-
- public void contextDestroyed(ServletContextEvent event) {
- ServletContext sc = event.getServletContext();
-
- sc.removeAttribute("dataSource");
- System.out.println("销毁工作完成...");
- }
-
-
- public void contextInitialized(ServletContextEvent event) {
-
-
- ServletContext sc = event.getServletContext();
-
-
- BasicDataSource bds = new BasicDataSource();
- bds.setDriverClassName("com.<a href="http:
- bds.setUsername("root");
- bds.setPassword("root");
- bds.setMaxActive(10);
- bds.setMaxIdle(5);
-
-
-
- sc.setAttribute("dataSource", bds);
- System.out.println("应用监听器初始化工作完成...");
- System.out.println("已经创建DataSource...");
- }
- }
web.xml中配置如下,很简单:
[c-sharp] view plain copy
- <!-- 配置应用监听器 -->
- <listener>
- <listener-class>dc.gz.listeners.MyServletContextListener</listener-class>
- </listener>
这样配置好了之后,以后在web应用中就可以通过ServletContext取得BasicDataSource对象,从而获取与数据库的连接,提高性能,方便使用。
3.拦截器
拦截器是在面向切面编程中应用的,就是在你的service或者一个方法前调用一个方法,或者在方法后调用一个方法。是基于JAVA的反射机制。拦截器不是在web.xml,比如struts在struts.xml中配置,
[c-sharp] view plain copy
- 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.过滤器
Servlet中的过滤器Filter是实现了javax.servlet.Filter接口的服务器端程序,依赖于servlet容器,主要的用途是过滤字符编码、做一些业务逻辑判断等。其工作原理是,只要你在web.xml文件配置好要拦截的客户端请求,它都会帮你拦截到请求,此时你就可以对请求或响应(Request、Response)统一设置编码,简化操作;同时还可进行逻辑判断,如用户是否已经登陆、有没有权限访问该页面等等工作。整个过程是基于函数回调完成的。它是随你的web应用启动而启动的,只初始化一次,以后就可以过滤几乎所有的相关请求,只有当你的web应用停止或重新部署的时候才销毁。
2.监听器
现在来说说Servlet的监听器Listener,它是实现了javax.servlet.ServletContextListener 接口的服务器端程序,它也是随web应用的启动而启动,只初始化一次,随web应用的停止而销毁。主要作用是:做一些初始化的内容添加工作、设置一些基本的内容、比如一些参数或者是一些固定的对象等等。
3.拦截器
拦截器是面向切面编程(AOP)的一种实现,就是在你的service或者一个方法前调用一个方法,或者在方法后调用一个方法。是基于Java的反射机制。拦截器不是在web.xml,比如struts在struts.xml中配置,或在spring的配置文件中配置,所以它不依赖于servlet容器。以Struts拦截器举例,拦截器只能对符合配置的请求起作用,而且可以访问action中的上下文、值栈里的对象,在action的生命周期中,拦截器可多次被调用。这些都是与过滤器所不同的。