mysql拦截器的应用场景_SpringBoot2 综合案例(04):多个拦截器配置和使用场景...

本文介绍了SpringBoot2中拦截器的使用,包括拦截器的基本概念、作用,以及如何编写和配置多个拦截器。通过示例展示了Token验证、请求数据校验和用户权限校验等应用场景,并提供了详细的日志输出来说明拦截器的执行顺序。
摘要由CSDN通过智能技术生成

拦截器简介

拦截器定义

拦截器,请求的接口被访问之前,进行拦截然后在之前或之后加入某些操作。拦截是 AOP 的一种实现策略。 拦截器主要用来按照指定规则拒绝请求。

拦截器中应用

Token 令牌验证

请求数据校验

用户权限校验

放行指定接口

SpringBoot2.0 拦截器用法

编写两个拦截器

自定义类实现 HandlerInterceptor 接口

1)OneInterceptor 拦截器

import org.slf4j.Logger;

import org.slf4j.LoggerFactory;

import org.springframework.web.servlet.HandlerInterceptor;

import org.springframework.web.servlet.ModelAndView;

import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpServletResponse;

/**

* 拦截器一

*/

public class OneInterceptor implements HandlerInterceptor {

private static final Logger LOGGER

= LoggerFactory.getLogger(OneInterceptor.class.getName());

@Override

public boolean preHandle(HttpServletRequest request,

HttpServletResponse response,

Object o) throws Exception {

String url =String.valueOf(request.getRequestURL()) ;

LOGGER.info("1、url=="+url);

// 放开拦截

return true;

}

@Override

public void postHandle(HttpServletRequest httpServletRequest,

HttpServletResponse httpServletResponse,

Object o, ModelAndView modelAndView) throws Exception {

LOGGER.info("1、postHandle");

}

@Override

public void afterCompletion(HttpServletRequest httpServletRequest,

HttpServletResponse httpServletResponse,

Object o, Exception e) throws Exception {

LOGGER.info("1、afterCompletion");

}

}

2)TwoInterceptor 拦截器

import org.slf4j.Logger;

import org.slf4j.LoggerFactory;

import org.springframework.web.servlet.HandlerInterceptor;

import org.springframework.web.servlet.ModelAndView;

import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpServletResponse;

/**

* 拦截器二

*/

public class TwoInterceptor implements HandlerInterceptor {

private static final Logger LOGGER

= LoggerFactory.getLogger(TwoInterceptor.class.getName());

@Override

public boolean preHandle(HttpServletRequest request,

HttpServletResponse response,

Object o) throws Exception {

String url =String.valueOf(request.getRequestURL()) ;

LOGGER.info("2、url=="+url);

// 放开拦截

return true;

}

@Override

public void postHandle(HttpServletRequest httpServletRequest,

HttpServletResponse httpServletResponse,

Object o, ModelAndView modelAndView) throws Exception {

LOGGER.info("2、postHandle");

}

@Override

public void afterCompletion(HttpServletRequest httpServletRequest,

HttpServletResponse httpServletResponse,

Object o, Exception e) throws Exception {

LOGGER.info("2、afterCompletion");

}

}

Web 配置文件中注入拦截器

import com.boot.intercept.intercept.OneInterceptor;

import com.boot.intercept.intercept.TwoInterceptor;

import org.springframework.context.annotation.Configuration;

import org.springframework.web.servlet.config.annotation.InterceptorRegistry;

import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;

/**

* Web 配置文件

*/

@Configuration

public class WebMvcConfig implements WebMvcConfigurer {

public void addInterceptors(InterceptorRegistry registry) {

// 拦截所有路径

// 注册自定义两个拦截器

registry.addInterceptor(new OneInterceptor()).addPathPatterns("/**");

registry.addInterceptor(new TwoInterceptor()).addPathPatterns("/**");

}

}

编写测试接口

import org.springframework.web.bind.annotation.RequestMapping;

import org.springframework.web.bind.annotation.RestController;

@RestController

public class InterceptController {

@RequestMapping("/reqUrl")

public String reqUrl (){

return "success" ;

}

}

访问测试接口

日志输出内容如下

intercept.OneInterceptor : 1、url==http://127.0.0.1:8005/reqUrl

intercept.TwoInterceptor : 2、url==http://127.0.0.1:8005/reqUrl

intercept.TwoInterceptor : 2、postHandle

intercept.OneInterceptor : 1、postHandle

intercept.TwoInterceptor : 2、afterCompletion

intercept.OneInterceptor : 1、afterCompletionla

拦截器的拦截顺序,是按照 Web 配置文件中注入拦截器的顺序执行的。

源代码地址

GitHub·地址

https://github.com/cicadasmile/spring-boot-base

GitEE·地址

https://gitee.com/cicadasmile/spring-boot-base

本文首发于 GitChat,未经授权不得转载,转载需与 GitChat 联系。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值