1:
import org.springframework.context.annotation.Configuration; import org.springframework.web.servlet.config.annotation.InterceptorRegistry; import org.springframework.web.servlet.config.annotation.WebMvcConfigurerAdapter; @Configuration public class MyWebConfig extends WebMvcConfigurerAdapter { /** * 注册 拦截器 */ @Override public void addInterceptors(InterceptorRegistry registry) { registry.addInterceptor(new MyInterceptor()); } }
2:
import com.ax.dmp.model.User; import com.ax.dmp.util.SessionUtils; import org.springframework.web.servlet.HandlerInterceptor; import org.springframework.web.servlet.ModelAndView; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import java.util.Arrays; import java.util.List; public class MyInterceptor implements HandlerInterceptor { /** * 不拦截的uri */ private static List<String> allowedURLS =Arrays.asList("/user/index","/user/login"); /** * controller 执行之前调用 */ @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { String uri = request.getRequestURI(); if(allowedURLS.contains(uri)){ return true; } // 登陆后会往session中放入User实体类,key与下行中getAttribute("key")的key对应上 User user = (User) request.getSession().getAttribute("key"); if(user==null){ response.sendRedirect("/user/index"); return false; } return true; } /** * controller 执行之后,且页面渲染之前调用 */ @Override public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception { } /** * 页面渲染之后调用,一般用于资源清理操作 */ @Override public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception { } }