zoukankan      html  css  js  c++  java
  • web应用怎么跳过某些Filter

    在做的项目需要用到cas,而使用cas的话,需要在client的webapp的web.xml中配置好多个filter,但是需要兼容到老的逻辑,如果满足某些条件,就不走cas的filter,满足另外一些条件,只走cas的其中几个filter,那该怎么进行filter的相关配置呢?

    从网上搜到了一片blog:http://blog.csdn.net/tandaly/article/details/8687671,里面讲述了两种方式。

    第一种是给filter设置标识。我目前考虑,在自己项目中采取这种为filter加标识的方式:

    publicclass FirstFilter implementsFilter {  
        //...  
       
        publicvoid doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain)throwsIOException, ServletException {  
            servletRequest.setAttribute("executeSecondFilter",true);  
            //...  
            if(someReason)  
                servletRequest.setAttribute("executeSecondFilter",false); 
           servletRequest.setAttribute("executeThirdFilter",false);
           servletRequest.setAttribute("executeForthFilter",true); filterChain.doFilter(servletRequest, servletResponse); } } publicclass SecondFilter implementsFilter {
    //.. publicvoid doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain)throwsIOException, ServletException { if(servletRequest.getAttribute("executeSecondFilter") == null|| !((Boolean) servletRequest.getAttribute("executeSecondFilter"))) { filterChain.doFilter(servletRequest, servletResponse); } //... } }
    publicclass ThirdFilter implementsFilter {  
        //..  
       
        publicvoid doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain)throwsIOException, ServletException {  
            if(servletRequest.getAttribute("executeThirdFilter") == null|| !((Boolean) servletRequest.getAttribute("executeThirdFilter"))) {  
                filterChain.doFilter(servletRequest, servletResponse);  
            }  
            //...  
        }  
    }
     

    filterChain.doFilter()的作用是跳转到filter链的下一个filter。

  • 相关阅读:
    编写安全检测脚本
    编写监控脚本
    编写一键部署软件脚本
    awk扩展应用
    sed基本用法
    字符串截取及切割,正则表达式,expect预期交互
    For,while,case,shell循环结构
    mybatis使用associaton进行分步查询
    mybatis中封装结果集常见示例
    Mybatis获取数据库自增主键
  • 原文地址:https://www.cnblogs.com/sonofelice/p/5143210.html
Copyright © 2011-2022 走看看