写一个拦截器 实现HandlerInterceptor。
package cn.fllday.interceptor;
import org.springframework.stereotype.Component;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import java.io.IOException;
/**
* 永无八阿哥
*
* @Author:gssznb
* @Date:Created 2019/2/2710:13
* @Description: 这是一个描述,但是我可能不会写
* @Modified By:
*/
@Component
public class IsLoginInter implements HandlerInterceptor {
//在请求处理之前进行调用(Controller方法调用之前
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) {
String url = request.getRequestURI();
System.out.println("本次请求的路径为: -----------------" + url + "------------------");
HttpSession session = request.getSession();
if (session.getAttribute(session.getId()) != null) {
// 返回true 表示 可以访问controller
return true;
}else {
try {
response.sendRedirect("/user/login.do");
} catch (IOException e) {
e.printStackTrace();
}
// 返回false 表示 禁止访问
return false;
}
}
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) {
}
@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) {
}
}
配置拦截器
package cn.fllday.config;
import cn.fllday.interceptor.IsLoginInter;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.*;
/**
* 永无八阿哥
*
* @Author:gssznb
* @Date:Created 2019/2/2710:18
* @Description: 这是一个描述,但是我可能不会写
* @Modified By:
*/
@Configuration
public class RegisterInterceptor extends WebMvcConfigurationSupport {
@Autowired
private IsLoginInter isLoginInter;
@Override
protected void addViewControllers(ViewControllerRegistry registry) {
registry.addViewController("/");
}
@Override
protected void addInterceptors(InterceptorRegistry registry) {
// 配置拦截器。 索要拦截的路径。 addPathPatterns “/**”表示所有的路径。excludePathPatterns 表示将要放行的路径,不对这些路径进行拦截
registry.addInterceptor(isLoginInter).addPathPatterns("/**").excludePathPatterns("/user/login.do","/static/**","/user/logout.do");
}
@Override
protected void addResourceHandlers(ResourceHandlerRegistry registry) {
// 配置拦截器不拦截的 静态资源
registry.addResourceHandler("/static/**")
.addResourceLocations("classpath:/static/");
registry.addResourceHandler("/templates/**")
.addResourceLocations("classpath:/templates/");
super.addResourceHandlers(registry);
}
}