JavaWeb Filter、Listener
Filter
Servlet用于处理用户请求,Filter(过滤器)用于拦截request、response,对request、response对象进行修改,在Servlet处理请求前后实现某些功能。
Filter接口
Filter是一个实现了javax.servlet.Filter接口的类。
Filter接口中的方法:
- init(FilterConfig filterFonfig) //初始化Filter
- doFilter(ServletRequest request, ServletResponse response, FilterChain chain) //拦截、过滤。chain对象表示Filter链。此方法是Filter的关键方法。
- destroy() //在web服务器移除Filter对象之前调用,释放Filter对象占用的资源
public void doFilter(ServletRequest req, ServletResponse resp, FilterChain chain) throws IOException, ServletException { //...... //去的时候拦截,做一些处理 chain.doFilter(req, resp); //放行 //...... //回来的时候拦截,做一些处理 }
Filter示例 统一全站编码
1 @WebFilter("/*") 2 public class HandlerFilter implements Filter { 3 public void init(FilterConfig config){ 4 } 5 6 public void doFilter(ServletRequest req, ServletResponse resp, FilterChain chain) throws IOException, ServletException { 7 req.setCharacterEncoding("utf-8"); 8 resp.setContentType("text/html;charset=utf-8"); 9 chain.doFilter(req, resp); 10 } 11 12 public void destroy() { 13 } 14 15 }
Filter的配置
Filter的配置方式和Servlet的配置方式差不多。
(1)xml配置
<filter> <filter-name>handlerFilter</filter-name> <filter-class>filter.HandlerFilter</filter-class> </filter> <filter-mapping> <filter-name>handlerFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>
(2)注解配置
@WebFilter("/*")
@WebFilter(filterName = "handlerFilter",urlPatterns = "/*")
Filter初始参数
在xml中配置Filter的初始参数:
<filter> <filter-name>handlerFilter</filter-name> <filter-class>filter.HandlerFilter</filter-class> <init-param> <param-name>name</param-name> <param-value>张三</param-value> </init-param> <init-param> <param-name>age</param-name> <param-value>20</param-value> </init-param> </filter>
或者在注解中配置:
@WebFilter( filterName = "handlerFilter", urlPatterns = "/*", initParams = {@WebInitParam(name = "name", value = "张三"),@WebInitParam(name="age",value = "12")} )
我们注意到Filter的init(FilterConfig config)有参数FilterConfig,Web服务器创建此Filter的实例时,会自动把xml或注解中这个Filter的初始参数以FilterConfig对象的形式注入。
在Filter中获取初始参数:
1 public class HandlerFilter implements Filter { 2 private FilterConfig filterConfig; //需要创建一个成员变量 3 public void init(FilterConfig config){ 4 this.filterConfig = config; //需要我们手动初始化 5 } 6 7 public void doFilter(ServletRequest req, ServletResponse resp, FilterChain chain) throws ServletException, IOException { 8 //获取单个初始参数的值 9 String name = filterConfig.getInitParameter("name"); //返回值是String,不存在该参数时返回null 10 String age = filterConfig.getInitParameter("age"); 11 System.out.println(name); 12 System.out.println(age); 13 14 //遍历 15 Enumeration<String> initParameterNames = filterConfig.getInitParameterNames(); 16 while (initParameterNames.hasMoreElements()){ 17 String paramName = initParameterNames.nextElement(); 18 String paramValue = filterConfig.getInitParameter(paramName); 19 System.out.println(paramValue); 20 } 21 22 chain.doFilter(req, resp); 23 } 24 25 public void destroy() { 26 } 27 28 }
Filter示例 自动登录
思路:
使用cookie存储账号、密码,使用Filter拦截,从cookie中取出账号、密码。若用户要注销|登出、不再想使用自动登录,将cookie的有效期设置为0即可。
浏览器可以查看Cookie,不能直接存储账号、密码的明文,使用Cookie存储账号、密码时需要加密,从Cookie中取出来时需要解密。
每次HTTP请求都使用Filter拦截,从Cookie中解密出账号、密码,每次都要解密,浪费时间。第一次从Cookie中解密出账号、密码后,可以将账号、密码放到session域中,会话期间直接从session中取,不必再解密。
Listener
Listener是Servlet的事件监听器,一共有8个:
- ServletContextListener 监听ServletContext对象的创建、销毁
- HttpSessionListener 监听HTTPSession对象的创建、销毁
- ServletRequestListener 监听ServletRequest对象的创建、销毁
- ServletContextAttributeListener 监听ServletContext中属性的变化(添加属性、移除属性、修改属性)
- HttpSessionAttributeListener
- ServletRequestAttributeListener
- HttpSessionBindListener 监听把JavaBean对象绑定到HttpSession对象上、把JavaBean对象从HttpSession对象上解绑
- HttpSessionActivationListener 监听HttpSession中对象的活化、钝化
钝化:HttpSession对象从内存中转移至硬盘
活化:HttpSession对象从持久化状态转变为运行状态
以上监听器均为接口,自己新建Listener实现即可。
xml注册Listener:
<listener> <listener-class>listener.MyListener</listener-class> </listener>
监听的是整个web应用,不是某个Servlet。
如需转载,请注明文章出处和来源网址:http://www.divcss5.com/html/h57410.shtml