1.what
filter过滤器的作用:拦截请求
2.why
网页上的某些操作或数据只有用户登录之后才能访问,用filter来过滤掉未登录的用户,只让已经登录的用户继续访问
3.for
利于数据的管理
4.code public class ManagerFilter implements Filter { @Override public void init(FilterConfig filterConfig) throws ServletException { } @Override public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException { HttpServletRequest httpServletRequest = (HttpServletRequest) servletRequest; Object user = httpServletRequest.getSession().getAttribute(“user”); if (user == null) { httpServletRequest.getRequestDispatcher(“/pages/user/login.jsp”).forward(servletRequest,servletResponse); } else { filterChain.doFilter(servletRequest,servletResponse); } } @Override public void destroy() { }} 5.多个filter链传递流程
1.再多个filter中,按照web.xml中filter的配置顺序执行filter类
6.filter在web.xml中的配置 <!–filter 标签用于配置一个 Filter 过滤器–><filter><!–给 filter 起一个别名–><filter-name>AdminFilter</filter-name><!–配置 filter 的全类名–><filter-class>com.atguigu.filter.AdminFilter</filter-class></filter><!–filter-mapping 配置 Filter 过滤器的拦截路径–><filter-mapping><!–filter-name 表示当前的拦截路径给哪个 filter 使用–><filter-name>AdminFilter</filter-name><url-pattern>/admin/ *</url-pattern>//给admin下所有页面都加上一个过滤器</filter-mapping> 7.生命周期
Filter 的生命周期包含几个方法
1) 构造器方法
2) init 初始化方法
第 1, 2 步, 在 web 工程启动的时候执行(Filter 已经创建)
3) doFilter 过滤方法
第 3 步, 每次拦截到请求, 就会执行
4) destroy 销毁
第 4 步, 停止 web 工程的时候, 就会执行(停止 web 工程, 也会销毁 Filter 过滤器)
8.细节
多个链在同一线程中,都可获取request中的参数
9. Filter 的拦截路径
–精确匹配
/target.jsp
以上配置的路径, 表示请求地址必须为: http://ip:port/工程路径/target.jsp
–目录匹配
/admin/
以上配置的路径, 表示请求地址必须为: http://ip:port/工程路径/admin/
–后缀名匹配
.html
以上配置的路径, 表示请求地址必须以.html 结尾才会拦截到
.do
以上配置的路径, 表示请求地址必须以.do 结尾才会拦截到
*.action
以上配置的路径, 表示请求地址必须以.action 结尾才会拦截到
Filter 过滤器它只关心请求的地址是否匹配, 不关心请求的资源是否存在! ! !