interceptor攔截器

fifter、servlet、interceptorhtml

    fifter用來處理請求頭、請求參數、編碼的一些設置,而後轉交給servlet,處理業務,返回
java

    servlet如今經常使用的spring,servlet攔截/到DispatcherServlet,交由spring管理web

    interceptor,servlet請求以後能夠實現HandlerInterceptor作到preHandle、postHandle、afterCompletion在controller以前、以後、渲染以後spring


登錄cookie

    業務中經常使用的登錄、註冊,大部分用cookie、session來作,這時候就涉及到攔截判斷用戶是否登錄、是否有權限?至此引出interceptor:session

   package com.bs.interceptor;

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

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

import com.bs.controller.BaseController;
import com.bs.entity.Member;

public class LoginInterceptor implements HandlerInterceptor {

	@Override
	public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)
			throws Exception {
		
		Member member = BaseController.getMemberByCookie(request);
		System.out.println(member);
		if(member == null){
			response.sendRedirect("/officialweb/login.html"); 
		}
		return false;
	}

	@Override
	public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler,
			ModelAndView modelAndView) throws Exception {
		// TODO Auto-generated method stub

	}

	@Override
	public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex)
			throws Exception {
		// TODO Auto-generated method stub

	}

}

    java代碼如上,而後在servlet.xml中配置以下:
mvc

 <!-- 攔截器 --> 
 <!--         多個攔截器,順序執行 -->
   <mvc:interceptors>  
         <mvc:interceptor>  
           <mvc:mapping path="/**"/>
            <mvc:exclude-mapping path="/**/cloud/**" />
            <mvc:exclude-mapping path="/**/login/**" />
            <bean class="com.bs.interceptor.LoginInterceptor"></bean> 
        </mvc:interceptor> 
    </mvc:interceptors>

    mvc:mapping攔截的path地址,mvc:exclude-mapping不攔截的path地址,好比一些登錄、註冊、驗證碼、和能夠不登陸操做的接口。app

    至此結束。
ide

相關文章
相關標籤/搜索