SpringBoot 中对拦截器的简单使用
共 4387字,需浏览 9分钟
·
2020-09-10 02:05
点击上方蓝色字体,选择“标星公众号”
优质文章,第一时间送达
明确需求
我们的部分接口需要访问者具有相应的权限才能进行相应的访问,即需要有正确的通行密码才能放行。看到这个需求,相应大家脑海中瞬间浮现出一个词 – 拦截器,确实,我们可以使用拦截器来实现这个需求,下面就让我来带领大家一起完成这个任务吧!
第一步:实现一个注解
首先,我们先实现一个注解,这个注解可以被加在方法上面,其主要功能如下:对于加上了这个注解的接口,会对其进行权限校验,通过才能执行下面的逻辑,否则会直接抛出异常。
package edu.szu.demo.annotation;
import java.lang.annotation.*;
// 作用于方法上
// 运行期保留
public Judge {
public boolean need() default true;
}
实现接口
我们的接口逻辑很简单,对于传入的字符串参数,稍作修改便直接返回。而我们的接口使用了之前定义的 @Judge 注解,意味着该接口需要进行校验。
package edu.szu.demo.controller;
import edu.szu.demo.annotation.Judge;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class TestController {
/**
* 该方法对传入数据做一定的修改,然后将其返回
* @param judgePassword 通行密码,通过校验才放行
* @param name 传入的数据
* @return
*/
@Judge
@RequestMapping("/test")
public String test(String judgePassword, String name) {
return name + " 已被修改";
}
}
实现一个拦截器
实现拦截器比较简单,既可以实现接口 HandlerInterceptor ,也可以继承抽象类 HandlerInterceptorAdapter,在这一步博主选择了实现接口。
我们先来看看这个 HandlerInterceptor 接口是何方神圣。
public interface HandlerInterceptor {
default boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
return true;
}
default void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, @Nullable ModelAndView modelAndView) throws Exception {
}
default void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, @Nullable Exception ex) throws Exception {
}
}
preHandle:在业务处理器处理请求之前被调用,可用于编码、安全控制、权限校验
postHandle:在业务处理器处理请求执行完成后,生成视图之前执行
afterCompletion:在 DispatcherServlet 完全处理完请求后被调用,可用于清理资源
明白了 HandlerInterceptor 的构造,我们便可以使用这个接口了。我们定义一个拦截器,该拦截器对于带有 Judge 注解的请求,会进行判断,若密码不为 happy,会直接抛出异常,其余情况均会放行。
package edu.szu.demo.interceptor;
import edu.szu.demo.annotation.Judge;
import org.springframework.web.method.HandlerMethod;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class TestInterceptor implements HandlerInterceptor {
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
HandlerMethod handlerMethod = (HandlerMethod) handler;
//获取注解
Judge judge = handlerMethod.getMethod().getAnnotation(Judge.class);
if(judge != null && judge.need()) {
String getJudgePassword = request.getParameter("judgePassword");
//这里直接写死,密码必须设置为 happy
if(!getJudgePassword.equals("happy")) {
throw new Exception();
}
}
return true;
}
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
}
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
}
}
注册拦截器
然后把我们前面写好的拦截器注册一下
package edu.szu.demo.config;
import edu.szu.demo.interceptor.TestInterceptor;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
public class WebAppConfigurer implements WebMvcConfigurer {
public void addInterceptors(InterceptorRegistry registry) {
// 拦截所有请求地址
registry.addInterceptor(new TestInterceptor()).addPathPatterns("/**");
}
}
这样子,我们的需求就已经实现了,接下来我们测试一下。
测试
在浏览器中我们输入以下 URL:
localhost:8080/test?judgePassword=happy&name=fdg
返回结果如下,可见对于添加了 @Judge 注解的接口,若 judgePassword 设置为 happy,拦截器会放行。
然后我们在浏览器输入以下 URL:
http://localhost:8080/test?judgePassword=not&name=fdg
返回结果如下,可见对于添加了 @Judge 注解的接口,若 judgePassword 设置不为 happy,拦截器会抛出异常。
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:
https://blog.csdn.net/Geffin/article/details/108405165
感谢点赞支持下哈