详细了解java监听器和过滤器

目录
  • 1、介绍:
  • 2、作用域对象:
  • Servt规范扩展-----------过滤器接口
    • 1、介绍:
    • 2、具体作用:
    • 3、Filter接口实现类的开发步骤:三步
      • 第一步:创建一个java类实现Filter接口
      • 第二步:重写doFilter接口中的doFilter()方法
      • 第三步:在web.xml文件中将过滤器接口实现类注册到Http服务器
    • OneServlet
    • TwoServlet
      • 4、Filter拦截地址的格式
  • 总结

1、介绍:

1)一组来自于Servlet规范下的接口,共有8个接口。在Tomcat中存在于Servlet-api.jar

2)监听器接口需要由开发人员亲自实现,Http服务器提供的jar中并没有对应的实现类

3)监听器接口用于监控【作用域对象生命周期的变化时刻】以及【作用域对象共享数据的变化时刻】

2、作用域对象:

1)在Servlet规范中,认为在服务端内存中可以在某些条件下为两个Servlet之间提供数据共享方案的对象,被称为【作用域对象】

2)在Servlet规范下的作用域对象:

ServletContext:全局作用域对象

HttpSession:会话作用域对象

HttpServletRequest:请求作用域对象

3、监听器接口实现类开发规范:三步

1)根据监听的实际情况,选择对应的监听器接口进行实现

2)重写监听器接口中声明的【监听事件处理方法】

3)在web.xml文件中将监听器接口实现类注册到Http服务器中

4、ServletContextListener

1)作用:通过这个接口合法的检测全局作用域对象的两个时刻

被初始化时刻 被销毁时刻

2)监听事件处理方法

public void contextInitialized():在全局作用域对象被Http服务器初始化是调用

public void contextDestroyed():在全局作用域对象被Http服务器销毁时调用

5、ServletContextAttributeListener接口:

1)作用:通过这个接口合法的检测全局作用域对象共享数据变化的时刻

2)监听事件处理方法:

public void contextAdded():在全局作用域对象添加共享数据时调用

public void contextReplaced():在全局作用域对象更新共享数据时调用

public void contextRemoved():在全局作用域对象删除共享数据时调用

6、全局作用域对象共享数据变化时刻

ServletContext application=request.getServletContext();

application.setAttribute("key1",100); //新增共享数据

application.setAttribute("key1",200); //更新共享数据

application.removeAttribute("key1"); //删除共享数据

代码实现

以下就以ServletContextListener接口和ServletContextAttributeListener接口

第一步:选择ServletContextListener接口进行实现

第二步:重写监听器接口声明的【监听事件处理方法】

public class OneListener implements ServletContextListener {
    @Override
    public void contextInitialized(ServletContextEvent sce) {
        System.out.println("Initialized............");
    }
    @Override
    public void contextDestroyed(ServletContextEvent sce) {
        System.out.println("Destroyed.............");
    }
}

第三步:在web.xml中将监听器接口实现类注册到Http服务器中

<listener>
    <listener-class>school.xauat.listener.OneListener</listener-class>
</listener>

由于ServletContext【全局作用对象的生命周期】贯穿网站的整个运行期间

Servlet之间数据共享中有具体的ServletContext生命周期

因此在Tomcat服务器启动过程时,执行contextInitialize()方法

Initialized............

在Tomcat服务器准备关闭时,执行contextDestroyed()方法

Destroyed.............

第一步:选择ServletContextAttributeListener接口进行实现

第二步:重写监听器接口声明的【监听事件处理方法】

public class OneListener implements ServletContextAttributeListener {
    @Override
    public void attributeAdded(ServletContextAttributeEvent scae) {
        System.out.println("ServletContextAttribute is added......");
    }
    @Override
    public void attributeRemoved(ServletContextAttributeEvent scae){
        System.out.println("ServletContextAttribute is removed......");
    }
    @Override
    public void attributeReplaced(ServletContextAttributeEvent scae){
        System.out.println("ServletContextAttribute is replaced......");
    }
}

第三步:在web.xml文件中将监听器接口实现类注册到Tomcat服务器中

<servlet>
    <servlet-name>OneServlet</servlet-name>
    <servlet-class>school.xauat.controller.OneServlet</servlet-class>
</servlet>
<servlet-mapping>
    <servlet-name>OneServlet</servlet-name>
    <url-pattern>/one</url-pattern>
</servlet-mapping>
<listener>
    <listener-class>school.xauat.listener.OneListener</listener-class>
</listener>

监听事件

public class OneServlet extends HttpServlet {
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //通过请求对象获取全局作用域对象
        ServletContext application=request.getServletContext();
        //向全局作用域对象中添加共享数据
        application.setAttribute("key",100);
        //更改全局作用域对象中的共享数据
        application.setAttribute("key",500);
        //删除全局作用域对象中的共享数据
        application.removeAttribute("key");
    }
}

运行结果

Servt规范扩展-----------过滤器接口

1、介绍:

1)来自于Servlet规范下的接口,在Tomcat中存在于servlet-api.jar包中

2)Filter接口实现类由开发人员负责提供的,Http服务器不负责提供

3)Filter接口会在Http服务器调用资源文件之前,对Http服务器进行拦截

2、具体作用:

1)拦截Http服务器,帮助Http服务器去检测当前请求的合法性

2)拦截Http服务器,对当前请求进行增强操作

3、Filter接口实现类的开发步骤:三步

1)创建一个java类实现Filter接口

2)重写Filter接口中的doFilter方法

3)在web.xml文件中将过滤器接口实现类注册到Http服务器

过滤器检测请求合法性

第一步:创建一个java类实现Filter接口

第二步:重写doFilter接口中的doFilter()方法

/**
 * http://localhost:8080/myWeb/mm.jpg?age=89
 */
public class OneFilter implements Filter {
    @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
        //通过拦截的请求对象来得到请求包中的参数信息,从而得到来访用户的真实年龄
        String age=servletRequest.getParameter("age");
        //根据这个年龄帮助我们的Http服务器判断本次请求的合法性
        if(Integer.valueOf(age)<70){
            //将拦截请求对象和相应对象交换给Tomcat,由Tomcat继续调用资源文件
            filterChain.doFilter(servletRequest,servletResponse);
        }else{
            //过滤器代替Http服务器拒绝本次请求
            servletResponse.setContentType("text/html;charset=utf-8");
            PrintWriter out=servletResponse.getWriter();
            out.print("<center><font style='color:red;font-size:40px'>不合适!!!!</font></center>");
        }
    }
}

第三步:在web.xml文件中将过滤器接口实现类注册到Http服务器

<!--将过滤器类文件交给Tomcat-->
<filter>
    <filter-name>OneFilter</filter-name>
    <filter-class>school.xauat.filter.OneFilter</filter-class>
</filter>
<!--通知Tomcat在调用何种资源文件是需要被当前过滤器拦截-->
<filter-mapping>
    <filter-name>OneFilter</filter-name>
    <url-pattern>/mm.jpg</url-pattern>
</filter-mapping>

过滤器对请求对象进行增强服务

当有多个以post的请求访问服务器时,需要对每个Servlet接口实现类中doPost()方法进行以下操作,增加的开发的难度。

response. setCharacterEncoding("utf-8")

以下展示过滤器的作用:

第一步:创建java实现Filter接口

第二步:重写Filter接口下的doFilter()方法

public class OneFilter implements Filter {
    @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
        servletRequest.setCharacterEncoding("utf-8");
        filterChain.doFilter(servletRequest,servletResponse);
    }
}

第三步:在web.xml文件中将过滤器接口实现类注册到Http服务器

<servlet>
        <servlet-name>OneServlet</servlet-name>
        <servlet-class>school.xauat.controller.OneServlet</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>OneServlet</servlet-name>
        <url-pattern>/one</url-pattern>
    </servlet-mapping>
    <servlet>
        <servlet-name>TwoServlet</servlet-name>
        <servlet-class>school.xauat.controller.TwoServlet</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>TwoServlet</servlet-name>
        <url-pattern>/two</url-pattern>
    </servlet-mapping>
    <!--注册Filter类-->
    <filter>
        <filter-name>OneFilter</filter-name>
        <filter-class>school.xauat.filter.OneFilter</filter-class>
    </filter>
    <filter-mapping>
        <filter-name>OneFilter</filter-name>
        <!--通知Tomcat在调用所有资源文件之前都需要调用OneFilter进行拦截-->
        <url-pattern>/*</url-pattern>
    </filter-mapping>

OneServlet

public class OneServlet extends HttpServlet {
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //通过请求对象获取请求体中的请求参数
        String userName=request.getParameter("userName");
        System.out.println("OneServlet----->"+userName);
    }
}

TwoServlet

public class TwoServlet extends HttpServlet {
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //通过请求对象获取请求体中的请求参数
        String userName=request.getParameter("userName");
        System.out.println("TwoServlet---->"+userName);
    }
}

4、Filter拦截地址的格式

1)命令格式:

<filter-mapping>

<filter-name><OneFilter/filter-name>

<url-pattern>拦截地址</url-pattern>

</filter-mapping>

2)命令作用:

拦截地址通知Tomcat在调用和何种资源文件之前需要调用OneFilter过滤进行拦截

3)要求Tomcat在调用某一个具体文件之前,来调用OneFilter进行拦截

<url-pattern>/目录/文件名</url-pattern>

4)要求Tomcat在调用某一个文件夹下所有的资源文件之前,来调用OneFilter进行拦截

<url-pattern>/目录/*</url-pattern>

5)要求Tomcat在调用任意文件夹下的某种类型文件之前,来调用OneFilter拦截

<url-pattern>*.jpg</url-pattern>

6)要求Tomcat在调用网站中任意文件时,来调用OneFilter拦截

<url-pattern>/*</url-pattern>

总结

本篇文章就到这里了,希望能给你带来帮助,也希望你能够多多关注我们的更多内容!

(0)

相关推荐

  • 聊聊java 过滤器、监听器、拦截器的区别(终结篇)

    过滤器.监听器.拦截器概念 概念 1.servlet:servlet是一种运行服务器端的java应用程序,具有独立于平台和协议的特性, 可以动态生成web页面它工作在客户端请求与服务器响应的中间层: 2.filter:filter是一个可以复用的代码片段,可以用来转换HTTP请求,响应和头信息. 它不能产生一个请求或者响应,它只是修改对某一资源的请求或者响应: 3.listener:监听器,通过listener可以坚挺web服务器中某一执行动作,并根据其要求作出相应的响应. 就是在applica

  • Java中的拦截器、过滤器、监听器用法详解

    本文实例讲述了Java中的拦截器.过滤器.监听器用法.分享给大家供大家参考,具体如下: 一.拦截器 :是在面向切面编程的就是在你的service或者一个方法,前调用一个方法,或者在方法后调用一个方法比如动态代理就是拦截器的简单实现,在你调用方 法前打印出字符串(或者做其它业务逻辑的操作),也可以在你调用方法后打印出字符串,甚至在你抛出异常的时候做业务逻辑的操作. 1.Struts2拦截器是在访问某个Action或Action的某个方法,字段之前或之后实施拦截,并且Struts2拦截器是可插拔的,

  • 基于java servlet过滤器和监听器(详解)

    1 过滤器 1.过滤器是什么? servlet规范当中定义的一种特殊的组件,用于拦截容器的调用. 注:容器收到请求之后,如果有过滤器,会先调用过滤器,然后在调用servlet. 2.如何写一个过滤器? 1.写一个java类,实现Filter接口; 2.在接口方法中实现拦截方法; 3.配置过滤器(web.xml); 3.配置初始化参数 1.配置初始化参数.(init-param) 2.通过filterconfig提供的getinitparamenter方法读取初始化的值. 4.优先级: 当有多个过

  • 浅析JAVA中过滤器、监听器、拦截器的区别

    1.过滤器:所谓过滤器顾名思义是用来过滤的,在java web中,你传入的request,response提前过滤掉一些信息,或者提前设置一些参数,然后再传入servlet或者struts的action进行业务逻辑,比如过滤掉非法url(不是login.do的地址请求,如果用户没有登陆都过滤掉),或者在传入servlet或者struts的action前统一设置字符集,或者去除掉一些非法字符(聊天室经常用到的,一些骂人的话).filter 流程是线性的, url传来之后,检查之后,可保持原来的流程

  • 详细了解java监听器和过滤器

    目录 1.介绍: 2.作用域对象: Servt规范扩展-----------过滤器接口 1.介绍: 2.具体作用: 3.Filter接口实现类的开发步骤:三步 第一步:创建一个java类实现Filter接口 第二步:重写doFilter接口中的doFilter()方法 第三步:在web.xml文件中将过滤器接口实现类注册到Http服务器 OneServlet TwoServlet 4.Filter拦截地址的格式 总结 1.介绍: 1)一组来自于Servlet规范下的接口,共有8个接口.在Tomc

  • JavaWeb的监听器和过滤器你了解吗

    目录 1.监听器---->Context,Session 2.监听器三大作用域 3.属性监听器 4.过滤器 4.1过滤器的使用 4.2过滤器的拦截路径 4.3过滤器的拦截顺序 4.4过滤器的四种拦截方式 总结 1.监听器---->Context,Session what is listener? 监听器是一个接口内容由我们实现,会在特定时间被调用,监听器用于监听web应用中三大域对象(request,session,application),信息的创建,销毁,增加,修改,删除等动作的发生,然后

  • Java拦截器和过滤器的区别分析

    一.过滤器(filter) 过滤器处于客户端与Web资源(Servlet.JSP.HTML)之间,客户端与Web资源之间的请求和响应都要通过过滤器进行过滤.举例:在过滤器中定义了禁止访问192.10.10.1这个地址,那么当客户端发出访问192.10.10.1的请求时,经过过滤器后,客户端得到的响应是出现该IP禁止访问的提示.在java web中,你传入的request,response提前过滤掉一些信息,或者提前设置一些参数,然后再传入servlet或者struts的 action进行业务逻辑

  • Vue计算属性与侦听器和过滤器超详细介绍

    目录 1. 计算属性 1.1 使用方法 1.2 案例-购物车合计使用计算属性 2. 侦听器 3. 过滤器 1. 计算属性 1.1 使用方法 概述: 模板中放入太多的逻辑会让模板过重且难以维护,使用计算属性可以让模板变得简洁易于维护.计算属性是基于它们的响应式依赖进行缓存的,计算属性比较适合对多个变量或者对象进行处理后返回一个结果值,也就是数多个变量中的某一个值发生了变化则我们监控的这个值也就会发生变化. 计算属性定义在Vue对象中,通过关键词computed属性对象中定义一个个函数,并返回一个值

  • Java拦截器Interceptor和过滤器Filte的执行顺序和区别

    目录 1.实现原理不同 2.使用范围不同 3.触发时机不同 4.拦截的请求范围不同 5.注入Bean情况不同 6.控制执行顺序不同 1.实现原理不同 过滤器和拦截器 底层实现方式大不相同,过滤器 是基于函数回调的,拦截器 则是基于Java的反射机制(动态代理)实现的. 1.拦截器是基于java的反射机制的,而过滤器是基于函数回调 2.过滤器依赖与servlet容器,而拦截器不依赖与servlet容器 3.拦截器只能对action请求起作用,而过滤器则可以对几乎所有的请求起作用 4.拦截器可以访问

  • Spring拦截器和过滤器的区别在哪?

    一.概述 拦截器和过滤器 filter和拦截器的功能都是拦截,filter拦截的目标是servlet的执行,而拦截器拦截的是Spring MVC定义的概念,叫handler(常见的就是我们用RequestMapping定义出来的HandlerMethod).觉得它相似是因为Spring的handler就是DispatcherServlet使用的,而后者就是一个servlet.filter包围着dispatcherServlet,而它自己也想去执行一个目标handler,并在执行周围包裹着拦截器,

  • Java监听器的作用及用法代码示例

    监听器在JavaWeb开发中用得比较多 Java Web开发中的监听器(listener)就是application.session.request三个对象创建.销毁或者往其中添加修改删除属性时自动执行代码的功能组件,如下所示: ①ServletContextListener:对Servlet上下文的创建和销毁进行监听. ②ServletContextAttributeListener:监听Servlet上下文属性的添加.删除和替换. ③HttpSessionListener:对Session的

  • Spring Boot拦截器和过滤器实例解析

    这篇文章主要介绍了Spring Boot拦截器和过滤器实例解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 一.拦截器与过滤器 在讲Spring boot之前,我们先了解一下过滤器和拦截器.这两者在功能方面很类似,但是在具体技术实现方面,差距还是比较大的.在分析两者的区别之前,我们先理解一下AOP的概念,AOP不是一种具体的技术,而是一种编程思想.在面向对象编程的过程中,我们很容易通过继承.多态来解决纵向扩展. 但是对于横向的功能,比如,在所

  • SSM项目中使用拦截器和过滤器的实现示例

    一.拦截器概述 Spring MVC 也可以使用拦截器对请求进行拦截处理,用户可以自定义拦截器来实现特定 的功能,自定义的拦截器必须实现 HandlerInterceptor 接口 preHandle():这个方法在业务处理器处理请求之前被调用,在该方法中对用户请求 request 进行处理.如果程序员决定该拦截器对请求进行拦截处理后还要调用其他 的拦截器,或者是业务处理器去进行处理,则返回 true:如果程序员决定不需要 再调用其他的组件去处理请求,则返回 false. postHandle(

  • 关于SpringBoot创建存储令牌的媒介类和过滤器的问题

    之所以需要创建存储令牌的媒介类,是因为后面的filter界面要使用. 一.创建ThreadLocalToken类 创建ThreadLocalToken类的目的: 在com.example.emos.wx.config.shiro中创建ThreadLocalToken类. 写入如下代码: package com.example.emos.wx.config.shiro; import org.springframework.stereotype.Component; @Component publ

随机推荐