当前位置: 首页 > article >正文

Filter过滤器和Listener监听器

Filter:过滤器

        1、概念:

                web中的过滤器:当访问服务器的资源时,过滤器可以将请求拦截下来,完成一些特殊的功能

                过滤器的作用:一般用于完成通用的操作,如:登录验证,统一的编码处理,敏感字符过滤

        2、快速入门

                1、步骤:

                        1、定义一个类,实现接口filter

                        2、复写方法

                        3、配置拦截路径

                                1、web.xml

                                2、注释

                2、代码

@WebFilter("/*")//访问所有资源之前都会执行该过滤器
public class FilterDemo1 implements Filter {
    @Override
    public void init(FilterConfig filterConfig) throws ServletException {
       // Filter.super.init(filterConfig);
    }

    @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
        System.out.println("FilterDemo1被执行了");
        //放行
        filterChain.doFilter(servletRequest,servletResponse);
    }

    @Override
    public void destroy() {
        //Filter.super.destroy();
    }
}

        3、过滤器细节

                1、web.xml配置

<filter>
    <filter-name>demo1</filter-name>
    <filter-class>cn.itcast.filter.FilterDemo1</filter-class>
</filter>
<filter-mapping>
    <filter-name>demo1</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>

                2、过滤器执行流程

public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws ServletException, IOException {
   //对request对象请求消息增强
    System.out.println("filterDemo2放行...");
    chain.doFilter(request, response);//放行
    //对response对象的响应消息增强
    System.out.println("filterDemo2回来了..");
}

                        1、执行过滤器

                        2、执行放行代码后的资源

                        3、回来执行过滤器放行代码下边的代码

                3、过滤器生命周期方法

                        1、init:在服务器启动后,会创建Filter对象,然后调用init方法,只执行一次,用于加载资源

                        2、doFilter:每一次请求被拦截资源时,会执行,执行多次

                        3、destroy:在服务器关闭后,Filter对象会被销毁,如果服务器是正常关闭,则会执行destroy方法,只执行一次,用于释放资源

                4、过滤器配置详情

                    1、拦截路径配置

                        1、具体资源路径:/index.jsp  只有访问index.jsp资源时,过滤器才会被执行

                        2、拦截目录:/user/*   访问/user下的所有资源时,过滤器都会被执行

                        3、后缀名拦截:  *.jsp  访问所有后缀名为jsp的资源时,过滤器都会执行

                        4、拦截所有资源:/*    访问所有资源时,过滤器都会执行

                     2、拦截方式配置:资源被访问的方式

                                注解配置:

                                        设置dispatcherTypes属性

                                        1、REQUEST request :默认值。浏览器直接请求资源

                                        2、FORWORD  forword:转发访问资源

                                        3、INCLUDE:  include  包含访问资源

                                        4、ERROR error  :错误跳转资源

                                        5、ASYNC  async  :异步访问资源

                                web.xml配置

                                        设置<dispatcher> </dispatcher>标签即可

                5、过滤器链(配置多个过滤器)

                        执行顺序:如果有两个过滤器:过滤器1和过滤器2

                                1、过滤器1

                                2、过滤器2

                                3、资源执行

                                4、过滤器2

                                5、过滤器1

                        过滤器先后配置:

                                1、注解配置:按照类名的字符串比较规则比较,值小的先执行

                                        如:AFilter和BFilter,AFilter就先执行了

                                2、web.xml配置:<filter-mapping>谁定义在上边,谁就先执行

增强对象的功能:

        设计模式:一些通用的解决固定问题的方法

        1.装饰模式

        2.代理模式

                概念:

                        1、真实对象:被代理的对象

                        2、代理对象:

                        3、代理模式:代理对象代理真实对象,达到增强真实对象功能的目的

                实现方式:

                        1、静态代理:有一个类文件描述代理模式

                        2、动态代理:在内存中形成代理类

                        实现步骤:

                                1、代理对象和真实对象实现相同的接口

                                2、代理对象 = Proxy.newProxyInstance();

                                3、使用代理对象调用方法

                                4、增强方法

                        增强方法:

                                1、增强参数列表

                                2、增强返回值类型

                                3、增强方法体执行逻辑

Listener:监听器

        概念:web的三大组件之一。

                事件监听机制

                        事件:一件事情

                        事件发生的地方

                        监听器:一个对象

                        注册监听:将事件、事件源、监听器绑定在一起。当事件源上发生某个事件后,执行监听代码

        ServletContextListener:监听ServletContext对象的创建和销毁

                void contextDestroyed(ServletContextEvent sce) :ServletContext对象被创建之前会调用该方法        

                void contextInitialized(ServletContextEvent sce):ServletContext对象创建后会调用该方法

        步骤:

                1、定义一个类,实现ServletContextListener接口

                2、复写方法

                3、配置

                        1、web.xml

<!--    <listener>-->
<!--        <listener-class>cn.itcast.web.listener.ContextLoaderListener</listener-class>-->
<!--    </listener>-->

                指定初始化参数<context-param>

                        2、注解

                                @WebListener

                                

                                


http://www.kler.cn/a/18021.html

相关文章:

  • 运行WHTools批量启动游戏房间工具提示要安装.Net Framework3.5解决
  • 详解kafka消息发送重试机制的案例
  • PaaS云原生:分布式集群中如何构建自动化压测工具
  • 【CICD】GitLab Runner 和执行器(Executor
  • Spring Boot 核心配置文件
  • Vue中优雅的使用Echarts的三种方式
  • 【致敬未来的攻城狮计划】— 连续打卡第二十五天:RA2E1的 DTC传输模式
  • 深入浅出堆—C语言版【数据结构】
  • 为什么需要使用Docker
  • 掌握这些GitHub搜索技巧,你的开发效率将翻倍!
  • 使用MindSDK的at-server组件开发从机模组
  • ScriptableObject上的prefab内容暂用,ScriptableObject详解
  • random — 伪随机数生成器(史上总结最全)
  • C++学习day--09 字符串比较、运算符
  • 【Java多线程编程】创建线程的基本方式
  • 【Linux】浅谈网络协议栈-网桥br0
  • 分布式锁Redisson对于(不可重入、不可重试、超时释放、主从一致性)四个问题的应对
  • Python人工智能—线性回归
  • C++面试题
  • java8新特性——StreamAPI
  • PyQt5零基础入门(二)——主窗口的显示与退出
  • LInux grep sed awk 命令详解
  • 开关电源基础01:电源变换器基础(3)
  • 数影周报:假冒ChatGPT的恶意软件激增,谷歌开启无密码登录
  • docker-mysql的几个问题
  • 学习HCIP的day.04