大家知道,框架中的拦截器就是用来拦截用户的请求,检查用户的每一个请求是否合法。那么我们基于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);
}
}
相关推荐
idea软件。SpringBoot的拦截器的博客所写的例子。preHandle()方法的返回值true和false的详细区别还未描述
springboot利用拦截器打印各个接口的响应时间,快速统计各接口执行速度,方便接口优化。springboot利用拦截器打印各个接口的响应时间,快速统计各接口执行速度,方便接口优化。springboot利用拦截器打印各个接口的响应...
SpringBoot 自定义拦截器 的 源代码 SpringBoot 自定义拦截器 一、自定义拦截器 二、编写控制器 三、添加拦截器对象,注入到容器的配置类中 另一种写法 四、最后application运行 我们对拦截器并不陌生,无论是 ...
主要介绍了SpringBoot拦截器原理解析及使用方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
本篇文章主要介绍了SpringBoot拦截器实现对404和500等错误的拦截,具有一定的参考价值,感兴趣的小伙伴们可以参考一下。
springboot spring aop 拦截器 注解方式实现脱敏(涉及到:pom.xml -->application.properties --->启动类-->拦截器)
简单的拦截器 对应文章:https://mp.csdn.net/postedit/88798536
SpringBoot中自定义拦截器示例代码SpringBoot中自定义拦截器示例代码
SpringBoot拦截器实现登录拦截的方法示例.docx
项目集成了sso资源拦截的控制,自己写了一个springBoot自定义的filter。可以减少一些不必要的资源拦截。自己做的一个小demo,共享于大家。
SpringBoot拦截器
LPSpringbootInterceptor源码 ... springboot中拦截器的配置 二、主要功能 实现了网页中除了登录页面之外都需要验证的拦截功能 三、注意事项 开发环境为idea2017,jdk1.8,springboot1.5,无数据库
该压缩包实现了利用过滤器或者拦截器对登录信息进行验证跳转登陆页的功能,利用的是SpringBoot和thymeleaf,使用前请先看使用说明
spring拦截器,高级参数绑定,controller返回值
SpringBoot整合Mybatis完整详细版含注册、登录、拦截器配置功能
主要介绍了Springboot引入拦截器并放行swagger代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
主要介绍了详解SpringBoot 解决拦截器注入Service为空问题的解决,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
自己整合的一个SpringBoot的Demo,告别了传统的web服务文件配置方式,实现了自定义拦截器与HTTPS请求的配置(使用Myeclipse打开,web加MAVEN型源码)
使用maven和jdk1.8 项目导入直接更改数据库连接即可使用
SpringBoot 简单登录功能 拦截器实现。 在实际开发中,我们经常会遇到某些页面需要登录才能查看的情况。下面使用拦截器实现该功能,在用户没有登录的情况下,将网站的所有访问都指向登录页面。 Springboot 登录