在具有登录功能的网站中,登录拦截极为重要,还好,在springboot里面实现这个并不是很麻烦
首先
我们先写一个拦截器的类,让它实现HandlerInterceptor接口,然后获取下当前用户信息,进行判断,如果为空,即表示没有登录,这时候进行拦截,并且放回一些信息,告诉前端没有权限,返回false,反之返回true
public class LoginHandlerInterceptor implements HandlerInterceptor {
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
//获取当前用户信息
Object loginUser = request.getSession().getAttribute("loginUser");
if (loginUser == null){
request.setAttribute("msg","没有权限,请先登录");
request.getRequestDispatcher("/login.html").forward(request,response);
}else {
return true;
}
return false;
}
}
其次
我们需要使用bean注入,调用上一步的类,创建一个关于Config的类,并且要实现WebMvcConfigurer接口,代码如下
@Configuration
public class MyMvcConfig implements WebMvcConfigurer {
@Override
public void addViewControllers(ViewControllerRegistry registry) {
registry.addViewController("/").setViewName("login");
registry.addViewController("/login").setViewName("login");
registry.addViewController("/login.html").setViewName("login");
}
@Override
public void addInterceptors(InterceptorRegistry registry) {
registry.addInterceptor(new LoginHandlerInterceptor())
//哪些路径需要拦截,这里我选择的是所有路径
.addPathPatterns("/**")
//处理哪些路径不拦截,登录页面当然不能拦截,还有一些静态资源
.excludePathPatterns("/login.html","/","/login",
"error.html","login","/css/**","/front/**","/images/*","/js/**");
}
}