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

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

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

    web.xml中 filter解析

    AdminFilter.java:
    package org.bluechant.mvc.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;

    import org.bluechant.mvc.core.GlobalSources;

    /**
     * 
    @author CHAOS
     * @date 2012-02-28 12:49
     * filter for check wheather user already login in ,
     * if not , send redirect to the login page 
     * if already login , forward user's request to the target request URL
     
    */

    public class AdminFilter implements Filter 
        
        
    private String loginPage ;
        
        
    private String loginAction ;
        
        
    private String userLoginTag ;
        
    //FilterConfig可用于訪問Filter的配置信息
        private FilterConfig config;

        
    //執行過濾的核心方法
        public void doFilter(ServletRequest req, ServletResponse res,
                FilterChain chain) 
    throws IOException, ServletException {
            
            HttpServletRequest request 
    = (HttpServletRequest) req;
            HttpServletResponse  response 
    = (HttpServletResponse )res;
            HttpSession session 
    = request.getSession(true);

            
    //獲取客戶請求的頁面
            String urlPath = request.getServletPath();
            
    //如果session范圍的user為null,即表明沒有登錄
            
    //且用戶請求的既不是登錄頁面,也不是處理登錄的頁面if( session.getAttribute("user") == null

            
    boolean flag = needNotFilter(urlPath);
            
    //不需要進行攔截的頁面
            if(!flag){
                Object obj 
    = session.getAttribute(userLoginTag);
                System.out.println(
    "the session userLoginTag value is :"+obj);
                
    if(obj!=null){
                    flag 
    = true ;
                }

            }

            
    if(flag){
                chain.doFilter(req, res);
            }
    else{
                
    //攔截不通過的時候跳轉到的目標//forward到登錄頁面
                response.sendRedirect(request.getContextPath()+loginPage);
            }

        }

        
    //只有在”/login.html“ || “/account!login.do” 情況下才進行攔截通過,否則攔截不通過跳到登陸頁面
        private boolean needNotFilter(String urlPath){
            
    if(urlPath.endsWith(loginPage) || urlPath.endsWith(loginAction)){
                
    return true ;
            }

            
    return false ;
        }


        
    /**
         * init params
         
    */

        
    public void init(FilterConfig config) throws ServletException {
            loginPage 
    = config.getInitParameter("loginPage");
            loginAction 
    = config.getInitParameter("loginAction");
            userLoginTag 
    = config.getInitParameter("userLoginTag");
            System.out.println(
    "the loginPage value is :"+loginPage);
            System.out.println(
    "the loginAction value is :"+loginAction);
            System.out.println(
    "the userLoginTag value is :"+userLoginTag);
            
    this.config = config;
            
    //以前頁面登陸的時候session進行設置HttpSession session = request.getSession(true);
            
    //session.setAttribute(GlobalSources.user_login_tag, user);
            GlobalSources.user_login_tag = userLoginTag ;//session放到GlobalSources,bean里,
    用GlobalSources.user_login_tag獲得

        }


        
    public void destroy(){
            
            
    this.config = null;
        }


    }


    web.xml中對應filter文件:
     <filter>
          <filter-name>adminFilter</filter-name>
          <filter-class>org.bluechant.mvc.filter.AdminFilter</filter-class>
              <init-param>
                   <param-name>loginAction</param-name>
                   <param-value>/account!login.do</param-value>
              </init-param>
              <init-param>
                   <param-name>loginPage</param-name>
                   <param-value>/login.html</param-value>
              </init-param>
              <init-param>
                   <param-name>userLoginTag</param-name>
                   <param-value>account_login_check</param-value>
              </init-param>  
     </filter>
     
     <filter>
              <filter-name>userSourceFilter</filter-name>
              <filter-class>org.bluechant.mvc.filter.AccountRoleFilter</filter-class>
     </filter>
     
     <filter-mapping>
              <filter-name>adminFilter</filter-name>
              <url-pattern>*.do</url-pattern><!-- 表明凡是訪問跳轉*.do形式的跳轉,都要運行名字為adminFilter的過濾器 -->
     </filter-mapping>
     
     <filter-mapping>
              <filter-name>userSourceFilter</filter-name>
              <url-pattern>*.do</url-pattern>
     </filter-mapping>

    posted on 2012-05-24 10:40 youngturk 閱讀(902) 評論(0)  編輯  收藏 所屬分類: web.xml解析

    <2012年5月>
    293012345
    6789101112
    13141516171819
    20212223242526
    272829303112
    3456789

    導航

    統計

    公告

    this year :
    1 jQuery
    2 freemarker
    3 框架結構
    4 口語英語

    常用鏈接

    留言簿(6)

    隨筆分類

    隨筆檔案

    文章分類

    文章檔案

    相冊

    EJB學習

    Flex學習

    learn English

    oracle

    spring MVC web service

    SQL

    Struts

    生活保健

    解析文件

    搜索

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 亚洲老熟女五十路老熟女bbw| 亚洲免费黄色网址| 亚洲AV无码码潮喷在线观看| 亚洲AV日韩精品久久久久久久 | 国产精品免费综合一区视频| 国产免费小视频在线观看| 久久久久亚洲AV无码专区网站| 亚洲中文字幕无码一久久区| 99亚洲精品高清一二区| 亚洲偷自精品三十六区| 免费视频精品一区二区| 抽搐一进一出gif免费视频| 99久久精品国产免费| 免费高清在线影片一区| 亚洲中文字幕视频国产| 亚洲国产精品久久久久网站 | 亚洲精品无码久久久久久| 污视频网站在线观看免费| a级毛片毛片免费观看久潮喷| xxxxwww免费| 国产无遮挡吃胸膜奶免费看| 亚洲线精品一区二区三区影音先锋| 亚洲图片在线观看| 久久亚洲中文字幕无码| 18禁在线无遮挡免费观看网站| 黄页网站在线看免费| 亚洲人午夜射精精品日韩| 久久久亚洲欧洲日产国码是AV| 亚洲国产av玩弄放荡人妇 | fc2免费人成在线视频| 久久九九兔免费精品6| 亚洲A∨精品一区二区三区| 久久夜色精品国产噜噜噜亚洲AV| 亚洲变态另类一区二区三区| 好久久免费视频高清| 免费看a级黄色片| 亚洲av综合色区| 激情无码亚洲一区二区三区| 久久久久久成人毛片免费看| 国产裸模视频免费区无码| 久久久亚洲欧洲日产国码aⅴ|