一、引言
我们日常开发中,经常会遇到这个场景:在访问系统功能前,需要用户登录,不登陆的话无法使用我们的系统,那么如果在每个方法前都加上登录代码...【emmm....我想应该不会有人这么干吧...】,常见的可以使用以下几种方式:
- 使用AOP切面功能来实现
- 实现WebMvcConfigurer接口,重写addCorsMappings()方法和addInterceptors()方法
下面我们就一起来看下一下怎么实现吧~
二、代码实现
AOP切面方式
切面方式配置的话,得配置到包路径下或者每个具体方法都要配置,个人不是很喜欢用切面的方式来配置拦截器,用来记录日志或者其他功能可以使用aop,这篇文章就不详细讲解了,只简单说明一下以切面方式实现时的大致模型,我们着重看下以另一种方式来实现拦截器的功能。
实现WebMvcConfigurer接口的方式
WebMvcConfigurer配置类其实是Spring内部的一种配置方式,采用JavaBean的形式来代替传统的xml配置文件形式进行针对框架个性化定制,可以自定义一些Handler,Interceptor,ViewResolver,MessageConverter。
基于java-based方式的spring mvc配置,需要创建一个配置类并实现WebMvcConfigurer 接口。在Spring Boot 1.5版本都是靠重写WebMvcConfigurerAdapter的方法来添加自定义拦截器,消息转换器等。SpringBoot 2.0 后,该类被标记为@Deprecated(弃用)。官方推荐直接实现WebMvcConfigurer或者直接继承WebMvcConfigurationSupport。
拦截器配置源码:
/** * 拦截器的属性配置 * * @Author 有梦想的肥宅 */ @Configuration//标识这是一个配置类 public class InterceptorConfiguration implements WebMvcConfigurer { /** * 重写addCorsMappings()解决跨域问题 * 配置:允许http请求进行跨域访问 * * @param registry * @Author 有梦想的肥宅 */ @Override public void addCorsMappings(CorsRegistry registry) { registry.addMapping("/**")//指哪些接口URL需要增加跨域设置 .allowedOrigins("*")//指的是前端哪些域名被允许跨域 .allowCredentials(true)//需要带cookie等凭证时,设置为true,就会把cookie的相关信息带上 .allowedMethods("GET", "HEAD", "POST", "PUT", "DELETE", "OPTIONS")//指的是允许哪些方法 .maxAge(3600);//cookie的失效时间,单位为秒(s),若设置为-1,则关闭浏览器就失效 } /** * 重写addInterceptors()实现拦截器 * 配置:要拦截的路径以及不拦截的路径 * * @param registry * @Author 有梦想的肥宅 */ @Override public void addInterceptors(InterceptorRegistry registry) { //注册Interceptor拦截器(Interceptor这个类是我们自己写的拦截器类) InterceptorRegistration registration = registry.addInterceptor(new Interceptor()); //addPathPatterns()方法添加需要拦截的路径 registration.addPathPatterns("/**"); //所有路径都被拦截 //excludePathPatterns()方法添加不拦截的路径 registration.excludePathPatterns( //添加不拦截路径 "/demo/loginPage", //登录页面的地址【不拦截】 "/**/*.html", //html静态资源 "/**/*.js", //js静态资源 "/**/*.css" //css静态资源 ); } }
自定义拦截器源码:
/** * 拦截器 * @Author 有梦想的肥宅 */ public class Interceptor implements HandlerInterceptor { /** * 在请求处理之前进行调用(Controller方法调用之前) * @Author 有梦想的肥宅 */ @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) { System.out.println("执行了Interceptor的preHandle方法"); try { //统一拦截(查询当前session是否存在UserInfoVO用户信息)(这里UserInfoVO会在每次登陆成功后,写入session) UserInfoVO user = (UserInfoVO) request.getSession().getAttribute("UserInfoVO"); if (user != null) { return true; } //这里设置拦截以后重定向的页面,一般设置为登陆页面地址 response.sendRedirect(request.getContextPath() + "/demo/loginPage"); } catch (IOException e) { e.printStackTrace(); } return true;//如果设置为false时,被请求时,拦截器执行到此处将不会继续操作 //如果设置为true时,请求将会继续执行后面的操作 } }
参考文章:
- SpringBoot---WebMvcConfigurer详解
- JAVA中Cookie MaxAge属性及其使用
- Springboot 拦截器配置(登录拦截)
- 跨域与拦截器同时配置导致跨域失败
- springBoot(6)---过滤器,监听器,拦截器
原文地址:https://www.cnblogs.com/riches/p/12638551.html
时间: 2024-10-11 09:02:19