<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    Servlet過(guò)濾器大全

    一、字符編碼的過(guò)濾器
    import javax.servlet.*
    import java.io.IOException; 

    /** 
    * 用于設(shè)置 HTTP 請(qǐng)求字符編碼的過(guò)濾器,通過(guò)過(guò)濾器參數(shù)encoding指明使用何種字符編碼,用于處理Html Form請(qǐng)求參數(shù)的中文問(wèn)題 
    */
     
    public class CharacterEncodingFilter 
    implements Filter 

    protected FilterConfig filterConfig = null
    protected String encoding = ""

    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException 

    if(encoding != null
    servletRequest.setCharacterEncoding(encoding); 
    filterChain.doFilter(servletRequest, servletResponse); 
    }
     

    public void destroy() 

    filterConfig 
    = null
    encoding 
    = null
    }
     

    public void init(FilterConfig filterConfig) throws ServletException 

    this.filterConfig = filterConfig; 
    this.encoding = filterConfig.getInitParameter("encoding"); 

    }
     
    }
     

    二、使瀏覽器不緩存頁(yè)面的過(guò)濾器
    import javax.servlet.*
    import javax.servlet.http.HttpServletResponse; 
    import java.io.IOException; 

    /** 
    * 用于的使 Browser 不緩存頁(yè)面的過(guò)濾器 
    */
     
    public class ForceNoCacheFilter implements Filter 

    public void doFilter(ServletRequest request, ServletResponse response, FilterChain filterChain) throws IOException, ServletException 

    ((HttpServletResponse) response).setHeader(
    "Cache-Control","no-cache"); 
    ((HttpServletResponse) response).setHeader(
    "Pragma","no-cache"); 
    ((HttpServletResponse) response).setDateHeader (
    "Expires"-1); 
    filterChain.doFilter(request, response); 
    }
     

    public void destroy() 
    }
     

    public void init(FilterConfig filterConfig) throws ServletException 
    }
     
    }
     

    三、檢測(cè)用戶(hù)是否登陸的過(guò)濾器
    import javax.servlet.*
    import javax.servlet.http.HttpServletRequest; 
    import javax.servlet.http.HttpServletResponse; 
    import javax.servlet.http.HttpSession; 
    import java.util.List; 
    import java.util.ArrayList; 
    import java.util.StringTokenizer; 
    import java.io.IOException; 

    /** 
    * 用于檢測(cè)用戶(hù)是否登陸的過(guò)濾器,如果未登錄,則重定向到指的登錄頁(yè)面 


    * 配置參數(shù) 


    * checkSessionKey 需檢查的在 Session 中保存的關(guān)鍵字 

    * redirectURL 如果用戶(hù)未登錄,則重定向到指定的頁(yè)面,URL不包括 ContextPath 

    * notCheckURLList 不做檢查的URL列表,以分號(hào)分開(kāi),并且 URL 中不包括 ContextPath 

    */
     
    public class CheckLoginFilter 
    implements Filter 

    protected FilterConfig filterConfig = null
    private String redirectURL = null
    private List notCheckURLList = new ArrayList(); 
    private String sessionKey = null

    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException 

    HttpServletRequest request 
    = (HttpServletRequest) servletRequest; 
    HttpServletResponse response 
    = (HttpServletResponse) servletResponse; 

    HttpSession session 
    = request.getSession(); 
    if(sessionKey == null

    filterChain.doFilter(request, response); 
    return
    }
     
    if((!checkRequestURIIntNotFilterList(request)) && session.getAttribute(sessionKey) == null

    response.sendRedirect(request.getContextPath() 
    + redirectURL); 
    return
    }
     
    filterChain.doFilter(servletRequest, servletResponse); 
    }
     

    public void destroy() 

    notCheckURLList.clear(); 
    }
     

    private boolean checkRequestURIIntNotFilterList(HttpServletRequest request) 

    String uri 
    = request.getServletPath() + (request.getPathInfo() == null ? "" : request.getPathInfo()); 
    return notCheckURLList.contains(uri); 
    }
     

    public void init(FilterConfig filterConfig) throws ServletException 

    this.filterConfig = filterConfig; 
    redirectURL 
    = filterConfig.getInitParameter("redirectURL"); 
    sessionKey 
    = filterConfig.getInitParameter("checkSessionKey"); 

    String notCheckURLListStr 
    = filterConfig.getInitParameter("notCheckURLList"); 

    if(notCheckURLListStr != null

    StringTokenizer st 
    = new StringTokenizer(notCheckURLListStr, ";"); 
    notCheckURLList.clear(); 
    while(st.hasMoreTokens()) 

    notCheckURLList.add(st.nextToken()); 
    }
     
    }
     
    }
     
    }
     

    四、資源保護(hù)過(guò)濾器
    package catalog.view.util; 

    import javax.servlet.Filter; 
    import javax.servlet.FilterConfig; 
    import javax.servlet.ServletRequest; 
    import javax.servlet.ServletResponse; 
    import javax.servlet.FilterChain; 
    import javax.servlet.ServletException; 
    import javax.servlet.http.HttpServletRequest; 
    import java.io.IOException; 
    import java.util.Iterator; 
    import java.util.Set; 
    import java.util.HashSet; 
    // 
    import org.apache.commons.logging.Log; 
    import org.apache.commons.logging.LogFactory; 

    /** 
    * This Filter class handle the security of the application. 

    * It should be configured inside the web.xml. 

    @author Derek Y. Shen 
    */
     
    public class SecurityFilter implements Filter 
    //the login page uri 
    private static final String LOGIN_PAGE_URI = "login.jsf"

    //the logger object 
    private Log logger = LogFactory.getLog(this.getClass()); 

    //a set of restricted resources 
    private Set restrictedResources; 

    /** 
    * Initializes the Filter. 
    */
     
    public void init(FilterConfig filterConfig) throws ServletException 
    this.restrictedResources = new HashSet(); 
    this.restrictedResources.add("/createProduct.jsf"); 
    this.restrictedResources.add("/editProduct.jsf"); 
    this.restrictedResources.add("/productList.jsf"); 
    }
     

    /** 
    * Standard doFilter object. 
    */
     
    public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain) 
    throws IOException, ServletException 
    this.logger.debug("doFilter"); 

    String contextPath 
    = ((HttpServletRequest)req).getContextPath(); 
    String requestUri 
    = ((HttpServletRequest)req).getRequestURI(); 

    this.logger.debug("contextPath = " + contextPath); 
    this.logger.debug("requestUri = " + requestUri); 

    if (this.contains(requestUri, contextPath) && !this.authorize((HttpServletRequest)req)) 
    this.logger.debug("authorization failed"); 
    ((HttpServletRequest)req).getRequestDispatcher(LOGIN_PAGE_URI).forward(req, res); 
    }
     
    else 
    this.logger.debug("authorization succeeded"); 
    chain.doFilter(req, res); 
    }
     
    }
     

    public void destroy() {} 

    private boolean contains(String value, String contextPath) 
    Iterator ite 
    = this.restrictedResources.iterator(); 

    while (ite.hasNext()) 
    String restrictedResource 
    = (String)ite.next(); 

    if ((contextPath + restrictedResource).equalsIgnoreCase(value)) 
    return true
    }
     
    }
     

    return false
    }
     

    private boolean authorize(HttpServletRequest req) 

    //處理用戶(hù)登錄 
    /* UserBean user = (UserBean)req.getSession().getAttribute(BeanNames.USER_BEAN); 

    if (user != null && user.getLoggedIn()) { 
    //user logged in 
    return true; 

    else { 
    return false; 
    }
    */
     
    }
     
    }
     

    五 利用Filter限制用戶(hù)瀏覽權(quán)限

    在一個(gè)系統(tǒng)中通常有多個(gè)權(quán)限的用戶(hù)。不同權(quán)限用戶(hù)的可以瀏覽不同的頁(yè)面。使用Filter進(jìn)行判斷不僅省下了代碼量,而且如果要更改的話只需要在Filter文件里動(dòng)下就可以。
    以下是Filter文件代碼:

    import java.io.IOException; 


    import javax.servlet.Filter; 
    import javax.servlet.FilterChain; 
    import javax.servlet.FilterConfig; 
    import javax.servlet.ServletException; 
    import javax.servlet.ServletRequest; 
    import javax.servlet.ServletResponse; 
    import javax.servlet.http.HttpServletRequest; 

    public class RightFilter implements Filter 

    public void destroy() 

    }
     

    public void doFilter(ServletRequest sreq, ServletResponse sres, FilterChain arg2) throws IOException, ServletException 
    // 獲取uri地址 
    HttpServletRequest request=(HttpServletRequest)sreq; 
    String uri 
    = request.getRequestURI(); 
    String ctx
    =request.getContextPath(); 
    uri 
    = uri.substring(ctx.length()); 
    //判斷admin級(jí)別網(wǎng)頁(yè)的瀏覽權(quán)限 
    if(uri.startsWith("/admin")) 
    if(request.getSession().getAttribute("admin")==null
    request.setAttribute(
    "message","您沒(méi)有這個(gè)權(quán)限"); 
    request.getRequestDispatcher(
    "/login.jsp").forward(sreq,sres); 
    return
    }
     
    }
     
    //判斷manage級(jí)別網(wǎng)頁(yè)的瀏覽權(quán)限 
    if(uri.startsWith("/manage")) 
    //這里省去 
    }
     
    }
     
    //下面還可以添加其他的用戶(hù)權(quán)限,省去。 

    }
     

    public void init(FilterConfig arg0) throws ServletException 

    }
     



    <!-- 判斷頁(yè)面的訪問(wèn)權(quán)限 --> 
    <filter> 
    <filter-name>RightFilter</filter-name> 
    <filter-class>cn.itkui.filter.RightFilter</filter-class> 
    </filter> 
    <filter-mapping> 
    <filter-name>RightFilter</filter-name> 
    <url-pattern>/admin/*</url-pattern> 
    </filter-mapping> 
    <filter-mapping> 
    <filter-name>RightFilter</filter-name> 
    <url-pattern>/manage/*</url-pattern> 
    </filter-mapping> 

    在web.xml中加入Filter的配置,如下: 
    <filter> 

    <filter-name>EncodingAndCacheflush</filter-name> 
    <filter-class>EncodingAndCacheflush</filter-class> 
    <init-param> 
    <param-name>encoding</param-name> 
    <param-value>UTF-8</param-value> 
    </init-param> 
    </filter> 
    <filter-mapping> 
    <filter-name>EncodingAndCacheflush</filter-name> 
    <url-pattern>/*</url-pattern> 
    </filter-mapping> 

    要傳遞參數(shù)的時(shí)候最好使用form進(jìn)行傳參,如果使用鏈接的話當(dāng)中文字符的時(shí)候過(guò)濾器轉(zhuǎn)碼是不會(huì)起作用的,還有就是頁(yè)面上

    form的method也要設(shè)置為post,不然過(guò)濾器也起不了作用。

    posted on 2008-09-05 19:17 翅膀 閱讀(9248) 評(píng)論(18)  編輯  收藏

    評(píng)論

    # re: 過(guò)濾器大全 2008-09-05 19:48 QBomber

    太好了~~學(xué)習(xí)~~  回復(fù)  更多評(píng)論   

    # re: Servlet過(guò)濾器大全 2008-09-06 09:05 johnnyhan

    總結(jié)得不錯(cuò)!  回復(fù)  更多評(píng)論   

    # re: Servlet過(guò)濾器大全 2008-09-06 09:44 shayne ward

    寫(xiě)的很不錯(cuò),學(xué)習(xí)拉。  回復(fù)  更多評(píng)論   

    # re: Servlet過(guò)濾器大全 2008-09-07 23:23 幻想

    學(xué)習(xí)了  回復(fù)  更多評(píng)論   

    # re: Servlet過(guò)濾器大全 2008-09-08 16:58 henry1451

    真的很不錯(cuò),學(xué)習(xí)了.  回復(fù)  更多評(píng)論   

    # re: Servlet過(guò)濾器大全 2008-09-12 14:16 25767139aa@163.com

    還有防止SQL 注入攻擊的權(quán)限
    類(lèi)型轉(zhuǎn)換封包過(guò)濾器
    權(quán)限過(guò)濾器,我只的是 用戶(hù)--》分配較色--->分配權(quán)限的  回復(fù)  更多評(píng)論   

    # re: Servlet過(guò)濾器大全 2008-10-08 11:05 米克

    好東東啊 ,  回復(fù)  更多評(píng)論   

    # re: Servlet過(guò)濾器大全 2009-01-13 19:02 過(guò)濾器學(xué)習(xí)

    不錯(cuò),很好謝謝學(xué)習(xí)  回復(fù)  更多評(píng)論   

    # re: Servlet過(guò)濾器大全 2009-02-15 13:14 小狼

    very good! mark.  回復(fù)  更多評(píng)論   

    # re: Servlet過(guò)濾器大全 2009-07-29 19:44 sdv

    寫(xiě)的很不錯(cuò)。  回復(fù)  更多評(píng)論   

    # re: Servlet過(guò)濾器大全 2009-08-20 16:50 q

    不錯(cuò)  回復(fù)  更多評(píng)論   

    # re: Servlet過(guò)濾器大全 2009-10-31 09:52 zfx

    太好了 頂一下  回復(fù)  更多評(píng)論   

    # re: Servlet過(guò)濾器大全[未登錄](méi) 2010-03-31 16:00 哈哈

    謝謝,非常好,涵蓋了幾乎所有要用到過(guò)濾器的地方  回復(fù)  更多評(píng)論   

    # re: Servlet過(guò)濾器大全[未登錄](méi) 2011-06-17 12:26 Neo

    I like this very much  回復(fù)  更多評(píng)論   

    # re: Servlet過(guò)濾器大全[未登錄](méi) 2011-07-25 14:10 aa

    很好  回復(fù)  更多評(píng)論   

    # re: Servlet過(guò)濾器大全[未登錄](méi) 2013-09-11 16:07 geek

    怎么js,css,jpg 這樣的也本攔截了?  回復(fù)  更多評(píng)論   

    # re: Servlet過(guò)濾器大全[未登錄](méi) 2013-11-15 15:30 tiger

    頂起  回復(fù)  更多評(píng)論   

    # re: Servlet過(guò)濾器大全[未登錄](méi) 2013-11-15 15:31 tiger

    我拿走了  回復(fù)  更多評(píng)論   


    只有注冊(cè)用戶(hù)登錄后才能發(fā)表評(píng)論。


    網(wǎng)站導(dǎo)航:
     
    <2008年9月>
    31123456
    78910111213
    14151617181920
    21222324252627
    2829301234
    567891011

    導(dǎo)航

    統(tǒng)計(jì)

    公告

     

    常用鏈接

    留言簿(2)

    隨筆檔案

    搜索

    最新評(píng)論

    閱讀排行榜

    評(píng)論排行榜

    主站蜘蛛池模板: 亚洲阿v天堂在线2017免费| 97热久久免费频精品99| 一级做a爰片久久免费| 大地资源中文在线观看免费版| 黄视频在线观看免费| 1000部啪啪毛片免费看| 国产亚洲精品免费| 亚洲av最新在线网址| 亚洲人成网站18禁止久久影院| 亚洲精品午夜视频| 黄网站色成年片大免费高清 | 国产国拍亚洲精品福利| 香蕉蕉亚亚洲aav综合| 日韩亚洲人成网站| 99精品视频在线免费观看| 毛片免费在线观看网站| 亚洲精品无码午夜福利中文字幕| 亚洲精品第一国产综合野| 精品无码国产污污污免费网站国产 | 亚洲开心婷婷中文字幕| 久久免费观看国产精品88av| 免费人成网站7777视频| 亚洲五月综合网色九月色| 日本特黄特黄刺激大片免费| 亚洲视频一区在线| 国产免费久久精品丫丫| 亚洲人成电影福利在线播放| 精品一区二区三区免费视频| 亚洲国产成人片在线观看无码| 日本特黄特色AAA大片免费| 热99re久久精品精品免费| 亚洲第一页中文字幕| 妞干网免费观看视频| 亚洲日本乱码卡2卡3卡新区| 午夜免费福利视频| 国产AV无码专区亚洲精品| 免费无码A片一区二三区 | 国产精品免费小视频| 亚洲娇小性xxxx色| JLZZJLZZ亚洲乱熟无码| 免费v片在线观看视频网站|