Android开发经验谈程序员@IT·互联网

Servlet中涉及到的Filter和Listener

2016-07-09  本文已影响424人  清枫_小天

Servlet中的过滤器和监听器详解

过滤器

Filter 并不是一个标准的Servlet ,它不能处理用户请求,也不能对客户端生成响应。主要用于对HttpServletRequest 进行预处理,也可以对HttpServletResponse 进行后处理,是个典型的处理链。

Servlet中的过滤器Filter是实现了javax.servlet.Filter接口的服务器端程序,主要的用途是过滤字符编码、做一些业务逻辑判断等。其工作原理是,只要你在web.xml文件配置好要拦截的客户端请求,它都会帮你拦截到请求,此时你就可以对请求或响应(Request、Response)统一设置编码,简化操作;同时还可进行逻辑判断,如用户是否已经登陆、有没有权限访问该页面等等工作。它是随你的web应用启动而启动的,只初始化一次,以后就可以拦截相关请求,只有当你的web应用停止或重新部署的时候才销毁,以下通过过滤编码的代码示例来了解它的使用:

过滤器类:

      public class EncodingFilter implements Filter {  
           public void destroy() {  
           
        }  
        public void doFilter(ServletRequest req, ServletResponse resp,  
                FilterChain chain) throws IOException, ServletException {  
    request.setCharacterEncoding("UTF-8");
    response.setCharacterEncoding("UTF-8");

    chain.doFilter(request, response);
    request.setCharacterEncoding("UTF-8");
    response.setCharacterEncoding("UTF-8");
            
        }  
        public void init(FilterConfig config) throws ServletException {  

        }
      }

配置文件

    <filter>
        <filter-name>encodingFilter</filter-name>
        <<filter-name>com.briup.filter.EncodingFilter</filter-name>
    </filter>
    <filter-mapping>
        <filter-name>encodingFilter</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>
Filter的执行顺序与在web.xml配置文件中的配置顺序一致,一般把Filter配置在所有的Servlet之前。

/表示过滤所有的servlet。/manager/表示过滤项目目录下的所有/manager的servlet

eg:当我们访问的时候通过了/manager时就必须会执行doFilter()这个方法。这个方法是判断顾客有没有登陆(如果顾客登陆过session中会有数据)。没有登陆会提示没有登陆并且进行登陆。代码如下:

/*
 * 这是一个过滤器:身份证过滤器
 */
@WebFilter("/manager/*")
public class AuthFilter implements Filter {
public void destroy() {
}
public void doFilter(ServletRequest request, ServletResponse response,
        FilterChain chain) throws IOException, ServletException {
    // 将ServletRequset转换为HttpServletRequset;
    if (request instanceof HttpServletRequest) {
        HttpServletRequest req = (HttpServletRequest) request;
        // 获取Session
        HttpSession session = req.getSession();
        // 判断session中有没有customer
        Customer customer = (Customer) session.getAttribute("customer");
        if (customer != null) {
            chain.doFilter(request, response);
        } else {
            request.setAttribute("msg", "你还没有登陆");
            request.getRequestDispatcher("/WEB-INF/jsp/login.jsp").forward(
                    request, response);
        }
    } else {
        request.setAttribute("msg", "你还没有登陆");
        request.getRequestDispatcher("/WEB-INF/jsp/login.jsp").forward(
                request, response);
    }
}
public void init(FilterConfig fConfig) throws ServletException {
}
}

监听器

现在来说说Servlet的监听器Listener,它是实现了javax.servlet.ServletContextListener 接口的服务器端程序,它也是随web应用的启动而启动,只初始化一次,随web应用的停止而销毁。主要作用是: 做一些初始化的内容添加工作、设置一些基本的内容、比如一些参数或者是一些固定的对象等等。下面利用监听器对数据库连接池DataSource的初始化演示它的使用
Listener是Servlet的监听器,它可以监听客户端的请求、服务端的操作等。通过监听器,可以自动激发一些操作,比如监听在线的用户的数量。当 增加一个HttpSession时,就激发sessionCreated(HttpSessionEvent se)方法,这样就可以给在线人数加1。常用的监听接口有以下几个:

ServletContextListener
ServletContextAttributeListener

SessionListener
SessionAttributeListener
SessionBindingListener

ServletRequestListener
ServletRequestAttributeListener    

以下是模拟一个当顾客登陆之后给他分配一个购物车情景。由于顾客登陆之后会用session储存信息。所以我们将购物车维护在session。具体代码如下:

public class MySessionListener implements HttpSessionListener {
public MySessionListener() {
    super();
    System.out.println("Listener创建了");
}
@Override
public void sessionCreated(HttpSessionEvent se) {
    // TODO Auto-generated method stub
    System.out.println("Session 创建sessionCreated");
    //当Session创建,在session中添加一个购物车
    se.getSession().setAttribute("shopcar", "购物车");
}
@Override
public void sessionDestroyed(HttpSessionEvent se) {
    // TODO Auto-generated method stub
    System.out.println("Session 销毁sessionDestroyed");
}

}

配置文件中web.xml

<listener>
<listener-class>com.briup.day03.MySessionListener
</listener-class>
</listener>
上一篇下一篇

猜你喜欢

热点阅读