SpringBoot 登录拦截器,这里的版本是2.0.4版本
1.编写拦截器实现类,实现接口 HandlerInterceptor,
重写里面需要的三个比较常用的方法,实现自己的业务逻辑代码
(就是自己拦截器拦截时做什么处理)
package com.bigbug.wanrong.travel.api.config;
import com.bigbug.wanrong.travel.api.model.User;
import org.apache.catalina.servlet4preview.http.HttpServletRequest;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.handler.HandlerInterceptorAdapter;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
public class SysInterceptor extends HandlerInterceptorAdapter {
/**
* 进入拦截器后首先进入的方法
* 返回false则不再继续执行
* 返回true则继续执行
*/
public boolean preHandle(HttpServletRequest request,
HttpServletResponse response, Object handler)throws Exception
{
System.out.println("我是拦截器:我证明我进来了");
HttpSession session=request.getSession();
User userInfo = (User)session.getAttribute("userInfo");
if(userInfo==null) {
System.out.println("我证明用户没有登录");
response.sendRedirect(request.getContextPath()+"/login.html"); // login.html 是你的登陆页地址
return false;
}
System.out.println("我证明用户已经登录");
return true;
}
/**
* 生成视图时执行,可以用来处理异常,并记录在日志中
*/
public void afterCompletion(HttpServletRequest request,
HttpServletResponse response,
Object arg2, Exception exception){
//-----------------//
}
/** -
* 生成视图之前执行,可以修改ModelAndView
*/
public void postHandle(HttpServletRequest request,
HttpServletResponse response,
Object arg2, ModelAndView arg3)
throws Exception{
//----------------------------//
}
}
编写拦截器配置文件类并继承 WebMvcConfigurer类,并重写其中的方法 addInterceptors并且在主类上加上注解 @Configuration
这里的是网上的常用拦截器,仅做个人学习记录。