<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视频全免费网站一区 美女视频黄a视频全免费网站色 | 91在线免费观看| 亚洲国产综合久久天堂| 瑟瑟网站免费网站入口| 亚洲精品第一国产综合精品99| 久久亚洲国产午夜精品理论片| 亚洲国产成人精品久久| h在线观看视频免费网站| 亚洲国产夜色在线观看| 青娱乐免费视频在线观看| 亚洲色一区二区三区四区| 国产成人精品免费直播| jzzjzz免费观看大片免费| 亚洲av无码国产精品夜色午夜| 亚洲高清国产拍精品熟女| 免费成人在线观看| 99精品视频在线观看免费| 亚洲国产成人久久综合一 | 无忧传媒视频免费观看入口| 国产免费av片在线无码免费看| 亚洲乱码中文论理电影| 日韩免费一区二区三区| www永久免费视频| 亚洲高清美女一区二区三区| 午夜免费福利在线观看| 一区二区三区免费视频观看| 亚洲AV午夜福利精品一区二区 | 女bbbbxxxx另类亚洲| 国产亚洲精品国看不卡| 69式互添免费视频| 成年大片免费高清在线看黄| 亚洲春色在线视频| 免费理论片51人人看电影| 中文字幕在线视频免费观看 | 2015日韩永久免费视频播放|