Filter过滤器快速入门教程(含Listener简介)

本文详细介绍了JavaWeb中的过滤器Filter和监听器Listener。Filter主要用于拦截和处理请求,如权限控制、编码统一等,通过定义Filter类,实现Filter接口并配置拦截路径。监听器Listener则可以监听应用程序、会话和请求中的事件,如对象的创建、销毁等。文中给出了LoginFilter的案例,展示了如何实现用户登录检查。
摘要由CSDN通过智能技术生成

Filter and Listener

一、概念

  • Filter 表示过滤器,是 JavaWeb 三大组件(Servlet、Filter、Listener)之一。
  • 过滤器可以把对资源的请求拦截下来,从而实现一些特殊的功能
  • 过滤器一般完成一些通用的操作,比如:权限控制、统一编码处理、敏感字符处理等等…

二、Filter 快速入门

  1. 定义类,实现 Filter 接口,并重写其所有方法
public class FilterDemo implements Filter {
    public void init(FilterConfig filterConfig) throws ServletException {}
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {}
    public void destroy() {}
}
  1. 配置Filter拦截资源的路径:在类上定义@WebFilter 注解
@WebServlet("/*")
public class FilterDemo implements Filter {...
  1. 在doFilter方法中输出一句话,并放行
public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
        System.out.println("filter被放行了");
        //放行
        filterChain.doFilter(servletRequest, servletResponse);
    }

三、Filter 执行流程

Filter执行流程

  1. 放行后访问对应资源,资源访问完成后,回到Filter中
  2. 回到Filter中,执行放行后的逻辑
执行放行前逻辑
放行
访问资源
执行放行后逻辑

注:放行前,对 Request 数据进行处理,放行后对 Response 数据进行处理

四、Filter 拦截路径配置

  • Filter 可以根据需求,配置不同的拦截资源路径
    Filter拦截路径
    • 拦截具体的资源:/index.jsp
    • 目录拦截:/user/*
    • 后缀名拦截:*.jsp
    • 拦截所有:/*

五、过滤器链

  • 一个Web应用,可以配置多个过滤器,这多个过滤器称为过滤器链
    过滤器链
  • 注解配置的Filter,优先级按照过滤器类名(字符串)的自然排序

六、案例

package com.itheima.web.filter;

import javax.servlet.*;
import javax.servlet.annotation.WebFilter;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpSession;
import java.io.IOException;

@WebFilter("/*")
public class LoginFilter implements Filter {

    public void init(FilterConfig filterConfig) throws ServletException {

    }

    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {

        HttpServletRequest req = (HttpServletRequest) servletRequest;

        //登陆注册相关界面,直接放行
        String[] urls = {"/login.jsp", "/register.jsp", "/checkCodeServlet", "/registerServlet", "/loginServlet","/imgs/", "/css/"};

        //访问路径
        String uri = req.getRequestURI().toString();

        for (String url : urls) {
            if(uri.contains(url)){
                filterChain.doFilter(req, servletResponse);
                return;
            }
        }

        HttpSession session = req.getSession();
        Object user = session.getAttribute("user");

        if (user == null) {
            //用户没有登录,返回登录界面
            req.setAttribute("login_msg", "您还没有登录");
            req.getRequestDispatcher("/login.jsp").forward(req, servletResponse);
        }else{
            //用户已经登录,放行
            filterChain.doFilter(req, servletResponse);
        }
    }

    public void destroy() {

    }
}

七、、Listener

  • 概念:Listener 表示监听器,是 JavaWeb 三大组件(Servlet、Filter、Listener)之一
  • 监听器可以监听是在application,session,request三个对象创建、销毁或者往其中添加修改删除属性时自动执行代码的功能组件
  • Listener分类:JavaWeb中提供了8个监听器
监听器分类监听器名称作用
ServletContext监听ServletContextListener用于对ServletContext对象进行监听(创建、销毁)
ServletContextAttributeListener对ServletContext对象中属性的监听
Session监听HttpSessionListener用于对Session对象进行监听(创建、销毁)
HttpSessionListener对Session对象中属性的监听
HttpSessionBindingListener监听对象与Session的绑定和解除
HttpSessionActivationListener对Session数据的钝化和活化进行监听
Request监听ServletRequestListener用于对Request对象进行监听(创建、销毁)
ServletRequestAttributeListener对Request对象中属性的监听
  • 使用方法:
    1. 实现对应接口
    2. 在类上添加WebListener注解





声明: 本文内容整理自:黑马程序员新版JavaWeb基础教程,Java web从入门到企业实战完整版

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

不想写代码的Rayoung

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值