过滤器(Filter)与监听器(Listener)知识点实例解析

一、过滤器(Filter)

1.1 什么是过滤器

过滤器实际上就是对web资源进⾏拦截,做⼀些处理后再交给下⼀个过滤器或servlet处理,通常都是⽤来拦截request进⾏处理的,也可以对返回的response进⾏拦截处理。

1.2 过滤器的语法格式

1.2.1 创建⼀个类实现Filter接口
public class CharSetFilter implements Filter{}
1.2.2 重写接口中的方法
public void destroy() { //销毁的⽅法}

public void doFilter(ServletRequest req, ServletResponse resp,FilterChain
chain) throws ServletException, IOException {
 //过滤⽅法 主要是对request和response进⾏⼀些处理,然后交给下⼀个过滤器或Servlet处理
 	chain.doFilter(req, resp);
 }
 
 public void init(FilterConfig config) throws ServletException {
 /*初始化⽅法 接收⼀个FilterConfig类型的参数 该参数是对Filter的⼀些配置*/
 }
1.2.3 在web.xml文件中配置
 <filter>
 <filter-name>过滤器名称</filter-name>
 <filter-class>过滤器所在的路径</filter-class>
 </filter>
 <filter-mapping>
 <filter-name>过滤器名称</filter-name>
 <url-pattern>需要过滤的资源</url-pattern>
 </filter-mapping>

1.3 Filter运用实例

FirstFilter.java创建Filter接口
public class FirstFilter implements Filter {
    @Override
    public void init(FilterConfig filterConfig) throws ServletException {
        System.out.println("初始化filter");//当服务器启动时执行init
    }

    @Override   //请求和响应时都会执行这个方法
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
        System.out.println("过滤器开始");
        //处理乱码
        HttpServletRequest request=(HttpServletRequest)servletRequest;
        HttpServletResponse response=(HttpServletResponse)servletResponse;
        request.setCharacterEncoding("utf-8");

        //防止用户在未登录的情况下访问资源
        String requestURI = request.getRequestURI();//获得请求地址
        System.out.println("requestURI="+requestURI);
        Object username = request.getSession().getAttribute("username");

        if(requestURI.endsWith("testsession.jsp")&&username==null){
            response.sendRedirect("index.jsp");
        }

        //调取下一个过滤器,或者调取servlet
        filterChain.doFilter(servletRequest, servletResponse);
        System.out.println("过滤器结束");

    }

    @Override
    public void destroy() {
        System.out.println("销毁filter");
    }
}
配置web.xml
    <filter>
        <filter-name>f1</filter-name>
        <filter-class>
            util.FirstFilter
        </filter-class>
    </filter>
    <filter-mapping>
        <filter-name>f1</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>

这里url-pattern需要过滤的资源/*代表的是所有资源都需要经过过滤器的处理,被过滤或再得到服务器端的响应。

测试结果

在这里插入图片描述

可以看到Filter是已经初始化的,再到页面进行测试。

在这里插入图片描述

如果用户名为空或者到成功登录的页面,会被Filter拦截

在这里插入图片描述


二、监听器(Listener)

2.1 什么是监听器

监听器就是监听某个域对象的的状态变化的组件

监听器的相关概念:

  • 事件源:被监听的对象(三个域对象 request、session、servletContext)
  • 监听器:监听事件源对象事件源对象的状态的变化都会触发监听器
  • 注册监听器:将监听器与事件源进⾏绑定
  • 响应⾏为:监听器监听到事件源的状态变化时所涉及的功能代码(程序员编写代码)

2.2 监听器分类

  • 第⼀维度按照被监听的对象划分:ServletRequest域、HttpSession域、ServletContext域
  • 第⼆维度按照监听的内容分:监听域对象的创建与销毁的、监听域对象的属性变化的
    在这里插入图片描述

2.3 监听三大域对象的创建与销毁的监听器

监听器的编写步骤(重点):

  • 编写⼀个监听器类去实现监听器接⼝
  • 覆盖监听器的⽅法
  • 需要在web.xml中进⾏配置—注册
<listener>
 <listener-class>监听器所在的路径</listener-class> 
</listener>

  • ServletContextListener
    监听ServletContext域的创建与销毁的监听器
  • Servlet域的生命周期
    何时创建:服务器启动创建
    何时销毁:服务器关闭销毁
  • ServletContextListener监听器的主要作用
    初始化的⼯作:初始化对象、初始化数据(加载数据库驱动、连接池的初始化)加载⼀些初始化的配置⽂件(spring的配置⽂件)任务调度(定时器—Timer/TimerTask)

  • HttpSessionListener
    监听Httpsession域的创建和销毁的监听器
  • HttpSession对象的⽣命周期
    何时创建:第⼀次调⽤request.getSession时创建
    何时销毁:服务器关闭销毁、session过期(默认30分钟,修改默认的30分钟是在Tomcat的web.xml,修改当前项⽬的过期时间是在⾃⼰项⽬的web.xml中)、手动销毁
  • HttpSessionListener监听器的主要作用:
    由于每次访问网站都会默认创建session对象(jsp⻚⾯中page指令中的session属性默认为true,即被访问时创建session),可以⽤于计数⽹站访问过的人

  • ServletRequestListener
    监听ServletRequest域创建与销毁的监听器
  • ServletRequest的⽣命周期
    创建:每⼀次请求都会创建request
    销毁:请求结束

2.4 Listener运用实例

  • 域对象的创建于销毁(HttpSession域)
2.4.1 创建SessionListener类实现HttpSessionListener接口
public class SessionListener implements HttpSessionListener {
    @Override
    public void sessionCreated(HttpSessionEvent httpSessionEvent) {
        System.out.println("session创建");
    }

    @Override
    public void sessionDestroyed(HttpSessionEvent httpSessionEvent) {
        System.out.println("session销毁");
    }
}
  • 域对象内属性的变化(HttpSession域)
2.4.2 创建AttributeListener类实现HttpSessionAttributeListener接口
public class AttributeListener implements HttpSessionAttributeListener {
    @Override
    public void attributeAdded(HttpSessionBindingEvent httpSessionBindingEvent) {
        System.out.println("session存值,"+httpSessionBindingEvent.getName()+","+httpSessionBindingEvent.getValue());
    }

    @Override
    public void attributeRemoved(HttpSessionBindingEvent httpSessionBindingEvent) {
        System.out.println("session移除数据");
    }

    @Override
    public void attributeReplaced(HttpSessionBindingEvent httpSessionBindingEvent) {

    }
}
2.4.3 配置web.xml
    <listener>
        <listener-class>util.SessionListener</listener-class>
    </listener>
    <listener>
        <listener-class>util.AttributeListener</listener-class>
    </listener>
2.4.4 测试

在这里插入图片描述

seesion在启动服务器的时候创建

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

监听器监听到域对象内的属性变化,seesion进行了存值,并且读取存储到的值。

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Spring Boot的监听器是用于监听应用程序中特定事件的组件,当这些事件发生时,监听器会执行相应的逻辑。 下面是一个简单的使用Spring Boot监听器的示例: 1. 创建一个自定义的监听器类,实现Spring的ApplicationListener接口。例如: ```java public class MyApplicationListener implements ApplicationListener<ApplicationReadyEvent> { @Override public void onApplicationEvent(ApplicationReadyEvent event) { // 处理应用程序启动完成事件 System.out.println("应用程序已启动!"); } } ``` 2. 在Spring Boot应用程序的入口类中,通过注解@EnableAutoConfiguration或@SpringBootApplication启用自动配置,并通过@ComponentScan扫描自定义监听器类。例如: ```java @EnableAutoConfiguration @ComponentScan public class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } } ``` 3. 运行应用程序时,自定义监听器的onApplicationEvent方法将会在应用程序启动完成时被调用。例如,当应用程序启动完成时,控制台将会打印出"应用程序已启动!"。 此外,Spring Boot还提供了其他类型的监听器,用于监听不同类型的事件,如应用程序启动前事件、应用程序关闭事件等。你可以根据需要实现不同的监听器,并注册到Spring Boot应用程序中。 总结:Spring Boot的监听器用于监听特定事件,并在事件发生时执行相应的逻辑。通过自定义监听器类和在入口类中注册监听器,我们可以方便地使用监听器来处理应用程序中的各种事件。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

12点前就睡

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

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

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

打赏作者

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

抵扣说明:

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

余额充值