监听器和过滤器
监听器
监听器的作用
在事件发生之前或之后进行数据的处理
使用方面:实现对应的接口
request:
- ①ServletRequestListener
- ②ServletRequestAttributeListener
session:
- ①HttpSessionListener
- ②HttpSessionAttributeListener
application:
- ①ServletContextListener
- ②ServletContextAttributeListener
接口中方法说明:
-
requestInitialized(ServletRequestEvent sre):
监听request对象完成初始化 -
attributeAdded(ServletRequestAttributeEvent srae):
监听往request中添加数据 -
attributeRemoved(ServletRequestAttributeEvent srae):
监听从request中删除数据 -
attributeReplaced(ServletRequestAttributeEvent srae):
监听从request中修改数据 -
requestDestroyed(ServletRequestEvent sre):
监听request对象销毁
注:session和context中有类似的方法
ServletRequestEvent对象中的常用方法代码示例
sre.getServletRequest();//获取request对象
sre.getServletContext();//获取context对象
ServletRequestAttributeEvent对象中常用方法代码示例
srae.getServletRequest();//获取request对象
监听器web.xml中的配置
在web3.0以后可以使用注解配置
@WebListener
过滤器
过滤器技术解决了什么问题
在请求被servlet处理之前,进行一次请求的效验,符合要求在调用对应的servlet进行处理
过滤器的使用
1.创建一个类实现filter接口
示例:
@WebFilter("/")
public class MyFilter implements Filter {
@Override
public void init(FilterConfig filterConfig) throws ServletException {
}
@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
throws IOException, ServletException {
chain.doFilter(request, response);
}
@Override
public void destroy() {
}
}
2.在web.xml中配置过滤器
在web3.0以后可以使用注解配置
@WebFileter("/*")
过滤器之拦截范围配置
- 拦截所有 /*
- 拦截部分 servlet 的请求 *.do
- 拦截 指定servlet的请求:/my
过滤器中都doFilter()方法的作用
服务器在接收到浏览器发送过来的请求后,先解析请求信息,创建对象request和respone然后根据请求url地址判断如果符合过滤器的过滤范围,则会调用过滤器的doFilter来进行请求拦截,并将request和response对象作为实参传递doFilter方法,我们可以在doFilter中声明过滤器拦截代码参数 servletRequest 接收此次拦截请求的的request实参servletResponse 接收此次拦截请求的