• 2020/2/9学习总结


    今天学习了关于filter过滤器的内容

    一 Filter 简介
    Filter也称之为过滤器,它是Servlet技术中最实用的技术,Web开发人员通过Filter技术,对web服务器管理的所有web资源:例如Jsp, Servlet, 静态图片文件或静态 html 文件等进行拦截,从而实现一些特殊的功能。例如实现URL级别的权限访问控制、过滤敏感词汇、压缩响应信息等一些高级功能。

    二Filter 生命周期
    Filter生命周期:

      实例化 --》 初始化 --》 服务 --》 销毁

       当服务器启动,会创建Filter对象,并调用init方法,只调用一次.

       当访问资源时,路径与Filter的拦截路径匹配,会执行Filter中的doFilter方法,这个方法是真正拦截操作的方法.

       当服务器关闭时,会调用Filter的destroy方法来进行销毁操作.

    三Filter创建

    • 创建一个类实现Filter接口
    • 重写接口中方法 doFilter方法是真正过滤的
    • 在web.xml文件中配置 

     注意:在Filter的doFilter方法内如果没有执行chain.doFilter(request,response)那么资源是不会被访问到的。

    public class FirstFilter implements Filter {
     
        @Override
        public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
     
            HttpServletRequest request=(HttpServletRequest)servletRequest;
            HttpServletResponse response=(HttpServletResponse)servletResponse;
     
            String remoteAddr=request.getRemoteAddr();
            String url=request.getRequestURL().toString();
            System.out.println(LocalDateTime.now() +" "+remoteAddr+" "+url);
     
            //放行,执行下一个过滤器
            filterChain.doFilter(request,response);
        }
     
        @Override
        public void init(FilterConfig filterConfig) throws ServletException {
             System.out.println("在 tomcat 服务器启动的时候filter 就会初始化");
        }
     
        @Override
        public void destroy() {
     
        }
    }
    <filter>
        <filter-name>firstFilter</filter-name>
        <filter-class>com.joe.filter.FirstFilter</filter-class>
    </filter>
    <filter-mapping>
        <filter-name>firstFilter</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>
  • 相关阅读:
    查看 Oracle 是32位还是64位的方法
    Oracle 查看 对象 持有 锁 的情况
    Oracle 11.2.0.3 Patchset
    Oracle 升级10.2.0.5.4 OPatch 报错Patch 12419392 Optional component(s) missing 解决方法
    Oracle 11.2.0.1 升级到 11.2.0.3 示例
    Oracle 安装OEM 报错: 无法对所有EM 相关账户解锁 解决方法
    Oracle sessions,processes 和 transactions 参数 关系 说明
    Oracle 11.2.0.1 升级到 11.2.0.3 示例
    Oracle 查看 对象 持有 锁 的情况
    Oracle Database Appliance
  • 原文地址:https://www.cnblogs.com/wangzhaojun1670/p/12296019.html
Copyright © 2020-2023  润新知