过滤器Filter的介绍和使用

1.简介

在 Java Web 开发中,Filter 是一个非常重要的组件,用于在请求到达 Servlet 之前或响应返回客户端之前对请求和响应进行预处理或后处理。Filter 可以用来实现多种功能,如日志记录、权限检查、编码转换、请求头修改等。就好比机场的层层安检,对前来的乘客进行检查过滤,携带违规物品,未买机票等不满足机场要求的就会被阻止进入。

2.Filter 的工作原理

  • 配置:在 web.xml 文件中或使用注解来配置 Filter

    web.xml中配置

<filter>
    <!--设置filter的别名-->
    <filter-name>LoggingFilter</filter-name>
    <!--filter的字节码路径-->
    <filter-class>com.example.LoggingFilter</filter-class>
</filter>

<filter-mapping>
  	<!--使用filter别名所对应的过滤路径,可以有多个-->
    <filter-name>LoggingFilter</filter-name>
     <!--/*表示对所有路径进行过滤-->
    <url-pattern>/*</url-pattern>
    <!--所要过滤的servlet的别名-->
    <servlet-name>servlet1</servlet-name>
</filter-mapping>

使用注解@WebFilter,它有如下几个常用的值:

  1. filterName: filter的别名相当于标签
  2. urlPatterns:所要过滤的资源url,相当于标签
  3. ServletNames:所要过滤的servlet别名,相当于 servletNames
@WebFilter(
        filterName = "loggingFilter",
        urlPatterns = {"/servlet1","*.html"},
        servletNames = {"servlet1","Servlet2"}
)
  • 拦截:当请求到达时,Filter 会拦截请求,并执行预处理逻辑。

    在请求到达目标资源前所执行的一些操作,如检查用户是否有权限访问记录、请求和响应的信息

  • 放行Filter 可以选择是否放行请求到目标资源(如 Servlet)。此时会执行FilterChaindoFilter方法代表放行。

    FilterChain表示Filter链,若对于该资源,后续还有其他Filter要进行过滤,此时的doFilter方法就会转而执行其他的Filter;若此时没有Filter要进行过滤,那么便会放行,进行目标资源的处理(如,servlet)

  • 后处理:在目标资源(如 Servlet)处理完请求后,Filter 可以对响应进行后处理。

3.Filter的生命周期

包括初创建始化过滤销毁四个阶段。

阶段对应方法执行时机执行次数
创建对象构造器web应用启动时1次
初始化方法void init(FilterConfig filterConfig)构造完毕1次
过滤请求void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain)每次请求多次
销毁default void destroy()web应用关闭时1次

特别注意的的时Filter在web应用启动时就创建了,并且进行初始化,这个过程只会出现一次。

4.Filter的执行顺序

一个web项目中,可以同时定义多个过滤器,当多个过滤器对同一个资源进行过滤时,工作位置有先后,整体形成一个工作链,称之为过滤器链(FilterChain

  • 当使用配置文件进行配置时

    过滤器链中的过滤器的顺序由<filter-mapping>标签的定义顺序决定

  • 当使用注解的方式进行配置时

    通常会把全部的过滤器放在一个包下,此时,执行顺序为类名的字典排序由小到大依次执行

5.一个简单的Filter的示例

案例要求:当用户访问资源时,检查其是否进行登陆,若未登录则跳转到登录页, 若以登录则放行

@WebFilter("/*")
public class CheckLoginFilter implements Filter {
    @Override
    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
            throws IOException, ServletException {
        //向下转型,实现重定向,获得session等功能
        HttpServletRequest httpRequest = (HttpServletRequest) request;
        HttpServletResponse httpResponse = (HttpServletResponse) response;

        // 检查用户是否已登录
        String user = (String) httpRequest.getSession().getAttribute("username");
        if (user == null) {
            // 用户未登录,重定向到登录页面
            httpResponse.sendRedirect(httpRequest.getContextPath() + "/login");
        } else {
            // 用户已登录,放行请求,注意是调用的FilterChain中的doFilter方法!!
            chain.doFilter(request, response);
        }
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值