<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 瘋狂 閱讀(8133) 評論(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
    很不錯,非常感謝

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


    網站導航:
     
    主站蜘蛛池模板: 亚洲伊人久久综合中文成人网| 亚洲一区中文字幕在线电影网| 中文字幕av无码无卡免费| 一级毛片a免费播放王色| 亚洲免费人成视频观看| 国产∨亚洲V天堂无码久久久| 国产一级高清免费观看| 99久久久国产精品免费无卡顿| 在线免费播放一级毛片| 男男gay做爽爽免费视频| 亚洲AV无码无限在线观看不卡 | 午夜亚洲www湿好大| 国产亚洲色婷婷久久99精品91| 在线免费观看视频你懂的| 国产成人精品免费视频网页大全| 91在线免费观看| 国产成人高清精品免费观看| 四虎一区二区成人免费影院网址 | 亚洲精品视频在线观看免费| 两个人看的www免费高清| 日韩在线一区二区三区免费视频 | 亚洲AV无码一区二区三区国产| 精品无码国产污污污免费| 欧美在线看片A免费观看| 真人做人试看60分钟免费视频 | 亚洲国产成a人v在线| 亚洲午夜免费视频| 亚洲国产精品婷婷久久| 久久亚洲春色中文字幕久久久| 亚洲AV无码一区二区二三区入口| 国产成人精品日本亚洲网站| 精品国产亚洲一区二区三区| 亚洲免费观看视频| 国产亚洲成AV人片在线观黄桃| 亚洲另类激情综合偷自拍图| 亚洲人成在线播放网站| 亚洲不卡av不卡一区二区| 亚洲AV无码专区国产乱码电影| 亚洲宅男永久在线| 亚洲免费在线视频观看| 亚洲欧美日韩中文二区|