Java 攔截器配置及使用


一、自定義攔截器,繼承HandlerInterceptorAdapter 類

1、新建 recordInterceptor 類

復制代碼
package com.panshi.ProjectInterceptor.Interceptor; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.stereotype.Component; import org.springframework.util.StringUtils; import org.springframework.web.servlet.ModelAndView; import org.springframework.web.servlet.handler.HandlerInterceptorAdapter; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpSession; @Component public class recordInterceptor extends HandlerInterceptorAdapter { private final static Logger logger= LoggerFactory.getLogger("interceptor"); /** * preHandle方法是進行處理器攔截用的,顧名思義,該方法將在Controller處理之前進行調用, * SpringMVC中的Interceptor攔截器是鏈式的,可以同時存在多個Interceptor, * 然后SpringMVC會根據聲明的前后順序一個接一個的執行, * 而且所有的Interceptor中的preHandle方法都會在Controller方法調用之前調用。 * SpringMVC的這種Interceptor鏈式結構也是可以進行中斷的, * 這種中斷方式是令preHandle的返回值為false,當preHandle的返回值為false的時候整個請求就結束了。 */ @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { logger.info("攔截了:"+request.getRequestURI()); HttpSession session=request.getSession(); if(!StringUtils.isEmpty(session.getAttribute("userId"))){ /** * 相關驗證 * */ return true; } else { response.sendRedirect("/logins"); return false; } //return super.preHandle(request, response, handler);  } /** * 這個方法只會在當前這個Interceptor的preHandle方法返回值為true的時候才會執行。 * postHandle是進行處理器攔截用的,它的執行時間是在處理器進行處理之 后, 也就是在Controller的方法調用之后執行, * 但是它會在DispatcherServlet進行視圖的渲染之前執行,也就是說在這個方法中你可以對ModelAndView進行操作。 * 這個方法的鏈式結構跟正常訪問的方向是相反的,也就是說先聲明的Interceptor攔截器該方法反而會后調用, * 這跟Struts2里面的攔截器的執行過程有點像, * 只是Struts2里面的intercept方法中要手動的調用ActionInvocation的invoke方法, * Struts2中調用ActionInvocation的invoke方法就是調用下一個Interceptor或者是調用action, * 然后要在Interceptor之前調用的內容都寫在調用invoke之前,要在Interceptor之后調用的內容都寫在調用invoke方法之后。 */ @Override public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception { } /** * 該方法也是需要當前對應的Interceptor的preHandle方法的返回值為true時才會執行。 * 該方法將在整個請求完成之后,也就是DispatcherServlet渲染了視圖執行, 這個方法的主要作用是用於清理資源的, */ @Override public void afterCompletion(HttpServletRequest request,HttpServletResponse response, Object handler, Exception ex) throws Exception { } }
復制代碼

 

二、注冊自定義攔截器,把定義的攔截器類加到SpringMVC的攔截體系中

1、新建 Interceptorconfig類

復制代碼
package com.panshi.ProjectInterceptor.Interceptor; import org.springframework.context.annotation.Configuration; import org.springframework.web.servlet.config.annotation.InterceptorRegistration; import org.springframework.web.servlet.config.annotation.InterceptorRegistry; import org.springframework.web.servlet.config.annotation.WebMvcConfigurationSupport; @Configuration public class Interceptorconfig extends WebMvcConfigurationSupport { @Override public void addInterceptors(InterceptorRegistry registry) { //可以通過此方法(addInterceptor())添加攔截器, 可以是spring提供的或者自己添加的 
InterceptorRegistration addInterceptor = registry.addInterceptor(getRecordInterceptor());
    // 排除配置
     addInterceptor.excludePathPatterns("/logins");  addInterceptor.excludePathPatterns("/loginout"); // 攔截配置
     addInterceptor.addPathPatterns("/**"); }

  @Bean
  public recordInterceptor getRecordInterceptor()
  {
  return new recordInterceptor();
  }
}
復制代碼

這樣,所有的action(除了logins 和 /loginout)都會被攔截。

getRecordInterceptor()


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM