day19 (Filter:过滤器)(Listener:监听器)

web三大组件:Servlet、Filter、Listener

Filter:过滤器

*生活中的过滤器:净水器,空气净化器,土匪截人

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

*过滤器的作用:

        1、一般用于完成通用的操作,例登录验证、统一编码处理、敏感字符处理。。。。。。

        2、快速入门

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

                2、复写方法

                3、配置(拦截路径)

                        1、web.xml配置

    <filter>
        <filter-name>demo2</filter-name>
        <filter-class>com.example.web.Filter.FilterDemo2</filter-class>
    </filter>
    <filter-mapping>
        <filter-name>demo2</filter-name>
         <!--拦截路径-->
        <url-pattern>/*</url-pattern>
    </filter-mapping>

                        2、注解:

@WebFilter("/*")//访问所有资源之前都会执行该过滤器。需要导入tomcat的servlet包

        3、过滤器细节

                1、web.xml配置

                2、过滤器执行流程

        1、执行过滤器
        2、执行放行后的资源
        3、回来执行过滤器放行代码下边的代码



         //对request对象请求消息增强
        System.out.println("filterdemo2执行了 ");
        //放行
        chain.doFilter(req, resp);
        //对response对象的响应消息增强
        System.out.println("filterdemo2回来了,");

                3、过滤器生命周期方法

                        1、init:服务器启动后,会创建filter对象,然后调用init方法。用于加载资源

                        2、destory:服务器关闭后,filter对象被销毁,如果服务器是正常关闭,然后调用destory方法。用于释放资源

                        3、dofilter:每一次请求被拦截时,都会执行。

package com.example.web.Filter;

import javax.servlet.*;
import javax.servlet.annotation.WebFilter;
import java.io.IOException;

@WebFilter("/*")
public class Filterdemo3 implements Filter {
    /**
     * 服务器关闭后,filter对象被销毁,如果服务器是正常关闭,然后调用destory方法
     * 用于释放资源
     */
    public void destroy() {
        System.out.println("destory...");
    }

    /**
     * 每一次请求被拦截时,都会执行
     * @param req
     * @param resp
     * @param chain
     * @throws ServletException
     * @throws IOException
     */
    public void doFilter(ServletRequest req, ServletResponse resp, FilterChain chain) throws ServletException, IOException {
        System.out.println("dofilter...");
        //放行
        chain.doFilter(req, resp);
    }

    /**
     * 服务器启动后,会创建filter对象,然后调用init方法
     * 用于加载资源
     * @param config
     * @throws ServletException
     */
    public void init(FilterConfig config) throws ServletException {
        System.out.println("init....");
    }

}

                4、过滤器配置详解

                        1、拦截路径配置

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

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

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

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

@WebFilter("/hello.jsp")  //1、具体资源路径:/index.jsp     只有访问index.jsp资源时,过滤器才会被执行
@WebFilter("/user/*")     //2、目录拦截:/user/*            访问/user目录下的所有资源时,过滤器都会被执行
@WebFilter("*.jsp")       //3、后缀名拦截:*.jsp            访问所有后缀名为jsp资源时,过滤器都会被执行
@WebFilter("/*")          //4、拦截所有资源:/*             访问所有资源时过滤器都会被执行


/user/* :这里 指的是servlet的路径,/user/findallServlet和/user/updateServlet

俺觉得名字叫做路径拦截更合适


@WebFilter("/*.jsp") : 指的是访问带有jsp路径的都会被拦截过滤

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

                                1、注解配置

                                        *要设置dispatcherTypes属性

//浏览器直接请求资源时,过滤器才会执行
@WebFilter(value = "/index.jsp",dispatcherTypes =DispatcherType.REQUEST )

//只有转发访问资源时,过滤器才会执行
@WebFilter(value = "/index.jsp",dispatcherTypes =DispatcherType.FORWARD )

//本身dispatcherTypes是一个数组,现在既可以直接访问拦截,也可以转发访问拦截
@WebFilter(value = "/index.jsp",dispatcherTypes ={DispatcherType.REQUEST,DispatcherType.FORWARD})

                                                1、request :默认值。浏览器直接请求资源才能被拦截

                                                2、forword :转发访问资源。只有转发的资源才能被拦截

                                                3、include : 包含访问资源。

                                                4、error :     错误跳转资源。

                                                5、async :   异步访问资源。

                                2、web.xml配置

                                        *在<filter-mapping>中, 设置<dispatcher></dispatcher>标签即可

    <filter>
        <filter-name>demo2</filter-name>
        <filter-class>com.example.web.Filter.FilterDemo1</filter-class>
    </filter>   
    <filter-mapping>
        <filter-name>demo2</filter-name>
        <!--拦截路径-->
        <url-pattern>/*</url-pattern>
        <dispatcher>REQUEST</dispatcher>
        <dispatcher>FORWARD</dispatcher>
        <dispatcher>INCLUDE</dispatcher>
        <dispatcher>ERROR</dispatcher>
        <dispatcher>ASYNC</dispatcher>
    </filter-mapping>

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

                        * 执行顺序:如果有两个过滤器:过滤器1和过滤器2
                                1. 过滤器1
                                2. 过滤器2
                                3. 资源执行
                                4. 过滤器2
                                5. 过滤器1 

                        * 过滤器先后顺序问题:
                                1. 注解配置:按照类名的字符串比较规则比较,值小的先执行
                                    * 如: AFilter 和 BFilter,AFilter就先执行了。
                                2. web.xml配置: <filter-mapping>谁定义在上边,谁先执行

        4、案例

                1、案例1-登录验证

                        * 需求:
                                1. 访问day17_case案例的资源。验证其是否登录
                                2. 如果登录了,则直接放行。
                                3. 如果没有登录,则跳转到登录页面,提示"您尚未登录,请先登录"。

                2、案例2-敏感词汇过滤

                        * 需求:
                                1. 对day17_case案例录入的数据进行敏感词汇过滤
                                2. 敏感词汇参考《敏感词汇.txt》
                                3. 如果是敏感词汇,替换为 *** 

                        * 分析:
                                1. 对request对象进行增强。增强获取参数相关方法
                                2. 放行。传递代理对象

                        * 增强对象的功能:
                                * 设计模式:一些通用的解决固定问题的方式
                                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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

universerobot

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

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

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

打赏作者

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

抵扣说明:

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

余额充值