首页 文章资讯内容详情

Springboot 拦截器配置(登录拦截)

2026-06-01 4 花语

本文内容纲要:

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