zoukankan      html  css  js  c++  java
  • Filter&Listener

    一、Filter:过滤器

         1. 概念:

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

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

          2.步骤:

                     * 定义一个类,实现接口Filter

                     * 复写方法

                     * 配置拦截路径:1.web.xml;2.注解:@WebFilter("/*")

               

    @WebFilter("/*")//访问所有资源之前,都会执行该过滤器
            public class FilterDemo1 implements Filter {
                @Override
                public void init(FilterConfig filterConfig) throws ServletException {
            
                }
            
                @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() {
            
                }
            }

        3.过滤器细节

              * web.xml配置

               <filter>
                <filter-name>demo1</filter-name>
                     <!--类的全路径-->
                <filter-class>cn.li.web.filter.FilterDemo1</filter-class>  
            </filter>
            <filter-mapping>
                <filter-name>demo1</filter-name>
                <!-- 拦截路径 -->
                <url-pattern>/*</url-pattern>
            </filter-mapping>

            *  过滤器执行流程

                  1. 执行过滤器

                  2. 执行放行后的资源

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

            * 过滤器生命周期方法

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

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

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

             * 过滤器配置详解

                    * 拦截路径配置:

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

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

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

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

              * 配置多个过滤器的顺序

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

                           过滤器1  ---> 过滤器2-----> 资源执行----->过滤器2-----> 过滤器1

                       *过滤器先后顺序问题:

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

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

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

    二、Listener:监听器

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

                 * 事件监听机制:事件 :一件事情

                                            事件源 :事件发生的地方

                                            监听器 :一个对象

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

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

                      * 步骤:

                               1. 定义一个类,实现ServletContextListener接口
                               2. 复写方法
                              3. 配置: web.xml

    <listener>
    <!--全路径类名-->
    <listener-class>cn.li.web.listener.ContextLoaderListener</listener-class>
    </listener>

                        4. 注解:
                                 @WebListener

             *  案例

    public class MyServletContextListener implements ServletContextListener {
    
        @Override
        //监听servletContext创建
        public void contextInitialized(ServletContextEvent sce) {
    
            //任务调度------定时器
            //银行计息 1.起始时间:晚上12点     2.间隔时间:24小时
            Timer timer =new Timer();
            //task:任务   firstTime:第一次执行时间  period:间隔执行时间
            //timer.scheduleAtFixedRate(task, firstTime, period);
              SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss"); 
              String currentTime="2020-3-10 00:00:00";
              Date parse=null;
              try {
                  parse = format.parse(currentTime);
            } catch (ParseException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
              
            timer.scheduleAtFixedRate(new TimerTask() {
                
                @Override
                public void run() {
                    System.out.println("来了+++++++");
                    
                }
            }, parse, 24*60*60*1000);
            
            
        }
  • 相关阅读:
    python中字典一键多相同值反转技巧
    win10下安装mysql
    上台阶问题的具体走法用python来实现
    桥接模式
    适配器模式
    多线程中lock的使用
    原型模式
    多线程
    建造者模式
    代理模式
  • 原文地址:https://www.cnblogs.com/cqyp/p/12454978.html
Copyright © 2011-2022 走看看