大家知道,框架中的拦截器就是用来拦截用户的请求,检查用户的每一个请求是否合法。那么我们基于SpringBoot框架,如何来使用拦截器呢?
1.定义拦截器
继承HandlerInterceptorAdapter类,该接口有三个方法,分别如下:
a.preHandle(用得比较多):预处理回调方法,实现处理器的预处理(如登录检查)
返回值:
true - 表示继续流程(如调用下一个拦截器或处理器);
false - 表示流程中断(如登录检查失败),不会继续调用其他的拦截器或处理器,此时我们需要通过response来产生响应;
b.postHandle:后处理回调方法,实现处理器的后处理(但在渲染视图之前),此时我们可以通过modelAndView(模型和视图对象)对模型数据进行处理或对视图进行处理,modelAndView也可能为null;
c.afterCompletion:整个请求处理完毕回调方法,即在视图渲染完毕时回调。
2.注册拦截器
添加拦截器配置类,继承WebMvcConfigurerAdapter类,使用@Configuration注解;注册一个或多个拦截器,多个拦截器便构成了拦截器链,执行顺序按注册的先后顺序执行。
3.拦截器使用实例(登录验证)
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.shiro.SecurityUtils;
import org.apache.shiro.session.Session;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.web.servlet.handler.HandlerInterceptorAdapter;
import com.alibaba.fastjson.JSON;
public class AuthInterceptor extends HandlerInterceptorAdapter {
private static final Logger logger = LoggerFactory.getLogger(AuthInterceptor.class);
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)
throws Exception {
logger.info("The request URL is: {}", request.getRequestURL());
Session session = SecurityUtils.getSubject().getSession();
logger.info("客户传递过来的session是:{}",session.getId().toString());
if ((Long) session.getAttribute("uid") != null || ((UserInfo) session.getAttribute("user")) != null) {
return true;
}else {
logger.info("你还没有登录,暂无访问权限");
// 向客户端输出提示信息
response.setContentType("application/json;charset=utf-8");
response.getWriter().write(JSON.toJSONString(new CommonResponseDataVo("你还没有登录,暂无访问权限",
SuccessFailEnum.FAIL.getCode(), SuccessFailEnum.FAIL.getMsg())));
return false;
}
}
}
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurerAdapter;
@Configuration
public class InterceptorConfig extends WebMvcConfigurerAdapter {
// 注册自定义的拦截器类
@Override
public void addInterceptors(InterceptorRegistry registry) {
// 加入自定义拦截器AuthInterceptor,可添加多个
registry.addInterceptor(new AuthInterceptor()).addPathPatterns("需要拦截的请求url");
//registry.addInterceptor("不同的拦截器").addPathPatterns("需要拦截的请求url");
super.addInterceptors(registry);
}
}
相关推荐
springboot利用拦截器打印各个接口的响应时间,快速统计各接口执行速度,方便接口优化。springboot利用拦截器打印各个接口的响应时间,快速统计各接口执行速度,方便接口优化。springboot利用拦截器打印各个接口的响应...
在本文中,我们将专注于如何使用SpringBoot拦截器来处理404和500等错误。 首先,创建自定义拦截器类并实现`HandlerInterceptor`接口是实现拦截器功能的第一步。如示例代码所示,我们需要创建一个名为`...
SpringBoot 自定义拦截器 的 源代码 SpringBoot 自定义拦截器 一、自定义拦截器 二、编写控制器 三、添加拦截器对象,注入到容器的配置类中 另一种写法 四、最后application运行 我们对拦截器并不陌生,无论是 ...
以上就是对SpringBoot拦截器原理解析及使用方法的详细介绍。拦截器的使用为开发人员提供了灵活的请求处理方式,可以方便地在请求到达控制器之前和之后加入自定义的逻辑。掌握拦截器的使用,对于开发安全、高效、易于...
在Spring Boot应用中,拦截器(Interceptor)是一个强大的工具,用于在请求被处理之前或之后执行自定义逻辑。本文将详细介绍如何在Spring Boot中实现拦截器以进行权限校验和登录验证,通过一个简单的Demo来阐述整个...
在开发拦截器时,我们可以使用@SpringBootTest来编写单元测试,确保拦截器的逻辑正确无误。 总结来说,Spring Boot中的拦截器是实现业务逻辑增强的关键工具,通过实现HandlerInterceptor接口并注册到Spring MVC配置...
基于Springboot前后端分离式,利用拦截器完成登录拦截的demo ## 项目备注 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信...
在这个名为"springboot-filter"的项目中,作者分享了一个简单的Filter实现,用以减少不必要的资源拦截。你可以通过查看源代码来学习如何集成SSO控制,以及如何根据具体需求定制Filter。这个示例是一个很好的起点,...
这个压缩包可能包含了一个示例项目,展示了如何在SpringBoot中配置和使用过滤器或拦截器进行登录验证。你可能需要解压并导入到IDE中,按照提供的说明运行和测试,以便更好地理解和学习这个功能。 通过深入理解这些...
Spring Boot整合了Spring MVC,因此我们可以利用Spring MVC的拦截器来实现各种功能,如权限验证、日志记录、性能监控等。本文将详细介绍如何在Spring Boot中设置拦截器,并通过四个基本的HTTP请求方法(PUT、DELETE...
在本项目中,我们主要探讨的是如何将SpringBoot与Mybatis进行深度整合,并实现完整的注册、登录功能,以及设置拦截器来控制权限访问。SpringBoot以其简洁的配置和快速的开发能力,配合Mybatis的灵活数据库操作,可以...
2. **配置拦截器**: 在Spring Boot的配置文件`application.yml`或`application.properties`中,我们需要配置MyBatis的拦截器,并将我们创建的`PaginationInterceptor`加入到拦截器链中。 ```yaml mybatis: ...
LPSpringbootInterceptor源码 ... springboot中拦截器的配置 二、主要功能 实现了网页中除了登录页面之外都需要验证的拦截功能 三、注意事项 开发环境为idea2017,jdk1.8,springboot1.5,无数据库
在本案例中,我们将探讨如何使用注解来实现拦截器,用于数据脱敏,这是保护敏感信息的一种常见方法。数据脱敏是指在展示或传输数据时,将敏感信息替换或隐藏,以确保隐私。 首先,让我们从`pom.xml`文件开始。在...
在Spring框架中,拦截器(Interceptor)是一种强大的工具,它允许开发者在请求处理前后执行自定义逻辑,例如日志记录、权限检查等。Spring MVC中的拦截器是基于AOP(面向切面编程)原理实现的,可以理解为对...
Springboot引入拦截器并放行Swagger代码实例 Springboot引入拦截器并放行Swagger代码实例是Springboot框架中一个非常重要的知识点。拦截器是Spring框架中的一种机制,用于在请求处理之前、处理过程中、处理之后执行...
在本项目"SpringBoot拦截器实现+HTTPSdemo"中,我们深入探讨了Spring Boot框架如何通过自定义拦截器实现Web应用程序的高级控制,并且演示了如何配置和启用HTTPS以确保数据传输的安全性。以下是关于这些知识点的详细...
SpringBoot拦截器中依赖注入为null的解决方法 在Spring Boot框架中,拦截器是一个常用的技术手段,用于处理请求和响应的逻辑。然而,在使用拦截器时,开发者可能会遇到依赖注入为null的问题。这主要是由于拦截器...
SpringBoot 拦截器是 SpringBoot 应用中一种重要的功能组件,它允许开发者在请求处理前后执行自定义逻辑,比如权限校验、日志记录、性能监控等。SpringBoot 拦截器基于Spring MVC框架中的HandlerInterceptor接口实现...
总的来说,解决SpringBoot拦截器注入Service为空的问题,关键在于确保Service所在包被扫描,拦截器被注册为Spring的Bean,并正确配置拦截规则。通过以上步骤,你应该能够成功地在拦截器中使用Service进行业务处理。...