Springboot自定义配置拦截器步骤详写

本文详细介绍了如何在SpringBoot项目中配置自定义的SpringMVC拦截器。首先,你需要创建一个名为MyInterceptor的类,实现HandlerInterceptor接口,并实现preHandle、postHandle和afterCompletion这三个方法。接着,创建MvcConfig配置类,实现WebMvcConfigurer接口,并在其中注册拦截器。最后,通过测试确保拦截器生效。同时,可以在application.properties中调整日志级别进行调试。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目标:在springboot项目里配置自定义springmvc拦截器
步骤:
1.编写拦截器
1)创建一个类MyInterceptor
2)实现HandlerInterceptor接口
3)实现接口里的三个方法
①:preHandle()
②:postHandle()
③:afterCompletion()

4)类的完整代码
package com.example.springbootdemo.myInterceptor;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.springframework.context.annotation.Configuration;
import org.springframework.stereotype.Component;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;

import lombok.extern.slf4j.Slf4j;

@Slf4j
//springmvc拦截器
public class MyInterceptor implements HandlerInterceptor {
	
	@Override
	//在业务处理器处理请求之前被调用。预处	理,可以进行编码、安全控制、权限校验等处理;
	public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)
			throws Exception {
		log.debug("这是拦截器的preHandle");
		return true;
	}
	
	@Override
	//在业务处理器处理请求执行完成后,生成视图之前执行。后处理(调用了Service并返回ModelAndView,但未进行页面渲染),有机会修改ModelAndView (这个博主就基本不怎么用了);
	public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler,
			ModelAndView modelAndView) throws Exception {
		log.debug("这是拦截器的postHandle");
			}
	
	@Override
	在DispatcherServlet完全处理完请求后被调用,可用于清理资源等。返回处理(已经渲染了页面);
	public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex)
			throws Exception {
		log.debug("这是拦截器的afterCompletion");
	}

}

2.编写配置类实现WebMvcConfigurer,在该类中添加各种组件(此时我添加配置拦截器)
1)创建MvcConfig配置类
2)实现WebMvcConfigurer接口
3)注册拦截器

//注册拦截器
	@Bean
	public MyInterceptor myInterceptor() {
		return new MyInterceptor();
	} 
4)添加拦截器到springmvc拦截器链

	@Override
	public void addInterceptors(InterceptorRegistry registry) {
		registry.addInterceptor(myInterceptor()).addPathPatterns("/**/*hello");
	}
5)完整代码
package com.example.springbootdemo.config;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;

import com.example.springbootdemo.myInterceptor.MyInterceptor;

//设置为配置类
@Configuration
public class MvcConfig implements WebMvcConfigurer {
	//注册拦截器
	@Bean
	public MyInterceptor myInterceptor() {
		return new MyInterceptor();
	} 
	//添加拦截器到springmvc拦截器链

	@Override
	public void addInterceptors(InterceptorRegistry registry) {
	//指定拦截的路径 基于ant风格
		registry.addInterceptor(myInterceptor()).addPathPatterns("/**/*hello");
	}
}

3.测试
在application.properties里配置日志的优先级

#日志记录级别
logging.level.com.example.springbootdemo=debug
logging.level.springframework=info

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值