Java 攔截器配置及使用
阿新 • • 發佈:2022-03-18
一、自定義攔截器,繼承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()
一、自定義攔截器,繼承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()