SpringBoot拦截器的使用

网友投稿 240 2022-11-23

SpringBoot拦截器的使用

目录一、拦截器简介二、拦截器配置使用方式1、过滤器拦截器作用范围2、拦截器的使用三、知识点总结1、拦截器的使用2、拦截器和过滤器的相同与不同

一、拦截器简介

拦截器通常通过动态代理的方式来执行。

拦截器的生命周期由IoC容器管理,可以通过注入等方式来获取其他Bean的实例,使用更方便。

二、拦截器配置使用方式

1、过滤器拦截器作用范围

2、拦截器的使用

示例代码如下:

package com.rongrong.wiki.interceptor;

import org.slf4j.Logger;

import org.slf4j.LoggerFactory;

import org.springframework.stereotype.Component;

import org.springframework.web.servlet.HandlerInterceptor;

import org.springframework.web.servlet.ModelAndView;

import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpServletResponse;

/**

* 拦截器:Spring框架特有的,常用于登录校验,权限校验,请求日志打印 /login

*/

@Component

public class LogInterceptor implements HandlerInterceptor {

private static final Logger LOG = LoggerFactory.getLogger(LogInterceptor.class);

@Override

public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {

// 打印请求信息

LOG.info("------------- LogInterceptor 开始 -------------");

LOG.info("请求地址: {} {}", request.getRequestURL().toString(), request.getMethod());

LOG.info("远程地址: {}", request.getRemoteAddr());

long startTime = System.currentTimeMillis();

request.setAttribute("requestStartTime", startTime);

return true;

}

@Override

public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {

long startTime = (Long) request.getAttribute("requestStartTime");

LOG.info("------------- LogInterceptor 结束 耗时:{} ms -------------", System.currentTimeMillis() - startTime);

}

}

将拦截器加入到配置中,示例代码如下:

package com.rongrong.wiki.config;

import com.rongrong.wiki.interceptor.LogInterceptor;

import org.springframework.context.annotation.Configuration;

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

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

import javax.annotation.Resource;

@Configuration

public class SpringMvcConfig implements WebMvcConfigurer {

@Resource

LogInterceptor loginInterceptor;

public void addInterceptors(InterceptorRegistry registry) {

registry.addInterceptor(loginInterceptor)

.addPathPatterns("/**")

.excludePathPatterns("/login");

}

}

重新编译启动,查看结果如下:

三、知识点总结

1、拦截器的使用

返回true会往后执行

返回false会结束,可以利用这点来做权限拦截

addPathPatterns() ,要拦截请求

excludePathPatterns() ,排除请求,不拦截

2、拦截器和过滤器的相同与不同

都可以用来统一处理请求,比如:打印日志、权限控制

过滤器依赖于servlet容器,拦截器依赖Spring框架

过滤器不用注入其它类,拦截器可注入其它类,基于这一点,建议能用拦截器的都用拦截器

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:树莓派是什么 能用来做什么
下一篇:区块链或将成为整治形式官僚主义的“大杀器”
相关文章

 发表评论

暂时没有评论,来抢沙发吧~