今天被一个朋友问起在SSH的项目中,过滤器、拦截器、监听器都分别是什么,又都是干什么用的。结合目前学习到的和自己应用的体会,大概有以下几个方面。
1.过滤器:顾名思义就是过滤请求内容的,所谓的过滤就是我们可以获得request对象中的值进行一系列的判断或者其他的操作。我们可以使其字符集编码格式改变等。具体的示例代码看下面的例子。
1 public class MyFilter implements javax.servlet.Filter { 2 /** 3 * 初始化 4 */ 5 @Override 6 public void init(FilterConfig arg0) throws ServletException { 7 } 8 /** 9 * 销毁 10 */ 11 @Override 12 public void destroy() { 13 } 14 /** 15 * 过滤 16 */ 17 @Override 18 public void doFilter(ServletRequest arg0, ServletResponse arg1, 19 FilterChain arg2) throws IOException, ServletException { 20 arg0.setCharacterEncoding("utf-8"); //设置request对象的字符集格式 21 arg2.doFilter(arg0, arg1); //继续执行 请求 22 } 23 }
这个是Filter实体的代码,在web.xml文件中我们需要对其需要拦截的请求配置监听范围,或者说过滤哪些url。
1 <filter> 2 <filter-name>myfilter</filter-name> 3 <filter-class>com.mine.test.MyFilter</filter-class> 4 </filter> 5 <filter-mapping> 6 <filter-name>myfilter</filter-name> 7 <url-pattern>/*</url-pattern> <!--配置过滤的范围 后缀符合即过滤 此处为全部过滤--> 8 </filter-mapping>
其实struts2本身就依托于一个总过滤器:
<filter> <filter-name>struts2</filter-name> <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class> </filter> <filter-mapping> <filter-name>struts2</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>
2. 拦截器 我们使用struts预定义过的拦截器时只需要做相应的配置即可,大多数常用的都会在default中有定义,而在struts.xml中不写就默认使用这个default。当我们自己创建了一个Intercepter对象时我们需要对其进行配置,具体配置的方法这里就不赘述了,戳此处 <a>http://www.blogjava.net/brock/archive/2009/08/20/291919.html</a> 。拦截器中有三个基本的方法对应其生命周期。
a.初始化 b.执行拦截 c.销毁。针对action请求进行处理,脱离了servlet API,不处理一般的url请求。
3. 监听器 我们常用的监听器一般会对一些对象进行监听。比如spring 的总监听器 会在服务器启动的时候实例化我们配置的bean对象 、 hibernate 的 session 的监听器会监听session的活动和生命周期,负责创建,关闭session等活动。
这里只是一个简单的认识,欢迎大家表达自己的观点。 邮箱:hpuzyp@163.com 欢迎来信交流。