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

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

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

    瘋狂

    STANDING ON THE SHOULDERS OF GIANTS
    posts - 481, comments - 486, trackbacks - 0, articles - 1
      BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

    初試Filter對權限和session的控制。

    Posted on 2007-10-09 18:25 瘋狂 閱讀(8142) 評論(6)  編輯  收藏
    用Filter防止用戶訪問一些未被授權的資源,比如一個用戶未登錄就不允許訪問網站的某些頁面,并將頁面重定向到需要用戶登錄的頁面,下面是一個相關的例子:

    package com.drp.util.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;
    import javax.servlet.http.HttpServletResponse;
    import javax.servlet.http.HttpSession;

    public class AuthFilter implements Filter {
     
     public void destroy() {

     }

     public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse,
       FilterChain filterChain) throws IOException, ServletException {//1,doFilter方法的第一個參數為ServletRequest對象。此對象給過濾器提供了對進入的信息(包括表單數據、cookie和HTTP請求頭)的完全訪問。第二個參數為ServletResponse,通常在簡單的過濾器中忽略此參數。最后一個參數為FilterChain,此參數用來調用servlet或JSP頁。

      HttpServletRequest request = (HttpServletRequest)servletRequest;//;//如果處理HTTP請求,并且需要訪問諸如getHeader或getCookies等在ServletRequest中無法得到的方法,就要把此request對象構造成HttpServletRequest
      HttpServletResponse response = (HttpServletResponse)servletResponse

      String currentURL = request.getRequestURI();//取得根目錄所對應的絕對路徑:

      
      String targetURL = currentURL.substring(currentURL.indexOf("/", 1), currentURL.length());  //截取到當前文件名用于比較

      HttpSession session = request.getSession(false);
      
      if (!"/login.jsp".equals(targetURL)) {//判斷當前頁是否是重定向以后的登錄頁面頁面,如果是就不做session的判斷,防止出現死循環
       if (session == null || session.getAttribute("user") == null) {//*用戶登錄以后需手動添加session
        System.out.println("request.getContextPath()=" + request.getContextPath());
        response.sendRedirect(request.getContextPath() + "/login.jsp");//如果session為空表示用戶沒有登錄就重定向到login.jsp頁面
        return;
       }
      }
      //加入filter鏈繼續向下執行
      filterChain.doFilter(request, response);//.調用FilterChain對象的doFilter方法。Filter接口的doFilter方法取一個FilterChain對象作為它的一個參數。在調用此對象的doFilter方法時,激活下一個相關的過濾器。如果沒有另一個過濾器與servlet或JSP頁面關聯,則servlet或JSP頁面被激活。

     }

     public void init(FilterConfig filterConfig) throws ServletException {

     }
    }
    然后在配置文件web.xml里添加: (請注意,過濾是在serlvet規范2.3版中初次引入的。因此,web.xml文件必須使用DTD的2.3以上版本。)
    <filter>
       <filter-name>AuthFilter</filter-name>
       <filter-class>com.drp.util.filter.AuthFilter</filter-class>
     </filter>
      
     <filter-mapping>
       <filter-name>AuthFilter</filter-name>
       <url-pattern>*.jsp</url-pattern>//表示對所有jsp文件有效
     </filter-mapping>

    這樣用戶沒有登錄的情況下就會轉到登錄頁面。

    評論

    # re: 初試Filter對權限和session的控制。  回復  更多評論   

    2007-10-09 18:53 by 快樂的豬豬
    不錯

    # re: 初試Filter對權限和session的控制。  回復  更多評論   

    2007-10-09 19:45 by 千里冰封
    不錯,挺有用的

    # re: 初試Filter對權限和session的控制。  回復  更多評論   

    2007-10-10 08:18 by 久城
    up!~剛好用過。:)

    PS: 1. 用filter處理字符集
    doFilter{
    request.setCharacterEncoding(encoding);
    chain.doFilter(request, response);
    }
    2. 用filter判斷user權限有效
    if (userId != null) {
    chain.doFilter(req, res);
    } else {
    req.getRequestDispatcher(TIMEOUT_ERROR_URL).forward(req, res);
    }

    # re: 初試Filter對權限和session的控制。  回復  更多評論   

    2007-10-13 21:06 by Crying
    HO HO! hao

    # re: 初試Filter對權限和session的控制。[未登錄]  回復  更多評論   

    2007-12-03 20:06 by 笨笨
    很有用,謝謝啦

    # re: 初試Filter對權限和session的控制。[未登錄]  回復  更多評論   

    2008-06-04 16:16 by chen
    很不錯,非常感謝

    只有注冊用戶登錄后才能發表評論。


    網站導航:
    博客園   IT新聞   Chat2DB   C++博客   博問  
     
    主站蜘蛛池模板: 免费看小12萝裸体视频国产| 亚洲无删减国产精品一区| 亚洲人成网站在线观看播放青青| 免费无码又爽又刺激高潮软件| 亚洲欧洲中文日韩久久AV乱码 | 亚洲AV综合色区无码二区爱AV| 香蕉免费一区二区三区| 毛片a级毛片免费观看免下载| 国产亚洲精品成人AA片| 最近中文字幕无免费视频 | 免费国产污网站在线观看不要卡| 在线免费观看韩国a视频| 特级毛片A级毛片免费播放| 亚洲高清免费视频| 中文在线观看免费网站| 免费网站看v片在线香蕉| 精品在线视频免费| 亚洲午夜福利AV一区二区无码| 亚洲一区在线免费观看| 永久免费bbbbbb视频| 一区二区三区AV高清免费波多| 国产香蕉九九久久精品免费| 亚洲精品亚洲人成在线| 亚洲第一成人影院| 嫩草在线视频www免费观看| 亚洲高清无在码在线电影不卡| 国产1024精品视频专区免费| 成a人片亚洲日本久久| 国产亚洲精品成人AA片新蒲金| 99久久精品免费精品国产| 久久久青草青青国产亚洲免观 | 亚洲αv久久久噜噜噜噜噜| 亚洲一级免费毛片| 精品亚洲视频在线| 亚洲AV一宅男色影视| 日韩精品无码区免费专区| 国产福利在线观看永久免费| 精品日韩亚洲AV无码一区二区三区| 好爽又高潮了毛片免费下载| 国产人成网在线播放VA免费| 亚洲一区二区影视|