Servlet中涉及到的Filter和Listener
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>