1. 程式人生 > 程式設計 >Spring interceptor攔截器配置及用法解析

Spring interceptor攔截器配置及用法解析

fifter、servlet、interceptor

fifter用來處理請求頭、請求引數、編碼的一些設定,然後轉交給servlet,處理業務,返回

servlet現在常用的spring,servlet攔截/到DispatcherServlet,交由spring管理

interceptor,servlet請求之後可以實現HandlerInterceptor做到preHandle、postHandle、afterCompletion在controller之前、之後、渲染之後

登陸

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

  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,Object handler,ModelAndView modelAndView) throws Exception {
		// TODO Auto-generated method stub

	}

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

java程式碼如上,然後在servlet.xml中配置如下:

 <!-- 攔截器 --> 
 <!--     多個攔截器,順序執行 -->
  <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地址,比如一些登陸、註冊、驗證碼、和可以不登入操作的介面。

至此結束。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。