一、Filter
1.1、概念
1.2、过滤器的作用
1.3、快速入门
步骤:
1、定义一个类实现接口Filter
2、复写方法
3、配置拦截路径
web.xml配置
注解配置
1.4、过滤器的细节
1.4.1、web.xml配置
<filter>
<filter-name>demo1</filter-name>
<filter-class>全类名</filter-class>
</filter>
<filter-mapping>
<filter-name>demo1</filter-name>
<!-- 拦截路径 -->
<url-pattern>/*</url-pattern>
</filter-mapping>
1.4.2、过滤器执行流程
1.4.3、过滤器生命周期方法
1.4.4、过滤器配置详解
拦截路径配置
:
拦截方式配置
:资源被访问的方式
注解配置:
设置dispatcherTypes属性
web.xml配置
设置<dispatcher></dispatcher>
标签即可
1.4.5、过滤器链(配置多个过滤器)
执行顺序:如果有两个过滤器:过滤器1和过滤器2
1. 过滤器1
2. 过滤器2
3. 资源执行
4. 过滤器2
5. 过滤器1
过滤器先后顺序问题:
1.5、案例1 登录验证
package com.zhou.test.web.filter;
import javax.servlet.*;
import javax.servlet.annotation.*;
import javax.servlet.http.HttpServletRequest;
import java.io.IOException;
@WebFilter("/*")
public class LoginFilter implements Filter {
public void init(FilterConfig config) throws ServletException {
}
public void destroy() {
}
@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws ServletException, IOException {
// 1、将request强转为httpServletRequest
HttpServletRequest request1 = (HttpServletRequest) request;
// 2、获取请求路径
String uri = request1.getRequestURI();
// 3、判断是否包含登录相关的资源
if (uri.contains("/login.jsp") || uri.contains("/loginServlet") || uri.contains("/css/") || uri.contains("/js/") || uri.contains("/fonts/") || uri.contains("/checkCodeServlet")){
// 包含 用户就是想登录 放行
chain.doFilter(request,response);
}else {
// 不包含 需要验证用户是否登录
// 从session中获取flag
String flag = (String) request1.getSession().getAttribute("flag");
if ("true".equals(flag)){
// 登陆了 放行
chain.doFilter(request,response);
}else {
// 没有登录 跳转到登录页面
request1.setAttribute("login_msg","您尚未登录,请先登录!");
request1.getRequestDispatcher("/login.jsp").forward(request1,response);
}
}
}
}
二、Listener
2.1、概念
web的三大组件之一
2.2、常用的监听对象
ServletContextListener
:监听ServletContext对象的创建和销毁
2.3、快速入门
步骤;
1、定义一个类实现ServletContextListener接口
2、复写方法
3、配置web.xml
类实现ServletContextListener接口
2、复写方法
3、配置web.xml