Springboot 拦截器配置(登录拦截)
本文内容纲要:
Springboot拦截器配置(登录拦截)
注意这里环境为springboot为2.1版本
1.编写拦截器实现类,实现接口HandlerInterceptor,
重写里面需要的三个比较常用的方法,实现自己的业务逻辑代码
(就是自己拦截器拦截时做什么处理)
packagecom.*.*.interceptor;
importjava.io.IOException;
importjavax.servlet.http.HttpServletRequest;
importjavax.servlet.http.HttpServletResponse;
importorg.springframework.web.servlet.HandlerInterceptor;
importorg.springframework.web.servlet.ModelAndView;
importcom.*.*.*.User;
/**
*
*
*@Package:com.*.*.interceptor
*@ClassName:AdminInterceptor
*@Description:拦截器
*@author:zk
*@date:2019年9月19日下午2:20:57
*/
publicclassAdminInterceptorimplementsHandlerInterceptor{
/**
*在请求处理之前进行调用(Controller方法调用之前)
*/
@Override
publicbooleanpreHandle(HttpServletRequestrequest,HttpServletResponseresponse,Objecthandler){
//System.out.println("执行了TestInterceptor的preHandle方法");
try{
//统一拦截(查询当前session是否存在user)(这里user会在每次登陆成功后,写入session)
Useruser=(User)request.getSession().getAttribute("USER");
if(user!=null){
returntrue;
}
response.sendRedirect(request.getContextPath()+"你的登陆页地址");
}catch(IOExceptione){
e.printStackTrace();
}
returnfalse;//如果设置为false时,被请求时,拦截器执行到此处将不会继续操作
//如果设置为true时,请求将会继续执行后面的操作
}
/**
*请求处理之后进行调用,但是在视图被渲染之前(Controller方法调用之后)
*/
@Override
publicvoidpostHandle(HttpServletRequestrequest,HttpServletResponseresponse,Objecthandler,ModelAndViewmodelAndView){
//System.out.println("执行了TestInterceptor的postHandle方法");
}
/**
*在整个请求结束之后被调用,也就是在DispatcherServlet渲染了对应的视图之后执行(主要是用于进行资源清理工作)
*/
@Override
publicvoidafterCompletion(HttpServletRequestrequest,HttpServletResponseresponse,Objecthandler,Exceptionex){
//System.out.println("执行了TestInterceptor的afterCompletion方法");
}
}
2.编写拦截器配置文件类并继承WebMvcConfigurer类,并重写其中的方法addInterceptors并且在主类上加上注解@Configuration
packagecom.*.*.config;
importorg.springframework.context.annotation.Configuration;
importorg.springframework.web.servlet.config.annotation.InterceptorRegistration;
importorg.springframework.web.servlet.config.annotation.InterceptorRegistry;
importorg.springframework.web.servlet.config.annotation.WebMvcConfigurer;
importcom.*.*.interceptor.AdminInterceptor;
/**
*
*
*@Package:com.*.*.config
*@ClassName:LoginConfig
*@Description:拦截器配置
*@author:zk
*@date:2019年9月19日下午2:18:35
*/
@Configuration
publicclassLoginConfigimplementsWebMvcConfigurer{
@Override
publicvoidaddInterceptors(InterceptorRegistryregistry){
//注册TestInterceptor拦截器
InterceptorRegistrationregistration=registry.addInterceptor(newAdminInterceptor());
registration.addPathPatterns("/**");//所有路径都被拦截
registration.excludePathPatterns(//添加不拦截路径
"你的登陆路径",//登录
"/**/*.html",//html静态资源
"/**/*.js",//js静态资源
"/**/*.css",//css静态资源
"/**/*.woff",
"/**/*.ttf"
);
}
}
这里不被拦截的路径,根据自己需求进行添加,上述主要是关于静态资源方面的
到这里后端拦截已经完成
我的项目是前后端分离的,前端使用的LayuiAdmin,借助了LayuiAdmin的前端拦截器进行相关html页面的拦截
结束
本文内容总结:
原文链接:https://www.cnblogs.com/zktww/p/11550891.html