SpringMVC的攔截器的使用

對所有的請求進行攔截,如果沒有登錄就返回到登錄頁面,簡單的SpringMVC的攔截器的使用案例


1、繼承HandlerInterceptor的登錄攔截器

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;

public class LoginInterceptor implements HandlerInterceptor {

    @Override
    public void afterCompletion(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, Exception arg3)
            throws Exception {
        // TODO Auto-generated method stub

    }

    @Override
    public void postHandle(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, ModelAndView arg3)
            throws Exception {
        // TODO Auto-generated method stub

    }

    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object arg2) throws Exception {
        // TODO Auto-generated method stub
        //判斷當前訪問路徑是否爲登錄的路徑,如果是則放行
        if(request.getRequestURI().indexOf("/login")>0){
            return true;
        }

        //判斷session中是否有登錄信息,如果沒有則跳轉到登錄界面,如果有則執行
        HttpSession session=request.getSession();
        if(session.getAttribute("username") !=null){
            return true;
        }

        request.getRequestDispatcher("/WEB-INF/jsp/login.jsp").forward(request, response);
        return false;
    }

}

springmvc.xml中的配置

<mvc:interceptors>
        <mvc:interceptor>
            <!-- 攔截請求的路徑    要攔截所有必需配置成/** -->
            <mvc:mapping path="/**"/>
            <!-- 指定攔截器的位置 -->
            <bean class="com.interceptor.LoginInterceptor"></bean>
        </mvc:interceptor>
    </mvc:interceptors>
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章