SpringBoot环境自定义拦截器

什么是拦截器
拦截器(Interceptor): 用于在某个方法被访问之前进行拦截,然后在方法执行之前或之后加入某些操作,它通过动态拦截Action调用的对象,允许开发者定义在一个action执行的前后执行的代码,也可以在一个action执行前阻止其执行。同时也是提供了一种可以提取action中可重用的部分的方式。

拦截器作用
拦截用户的请求并进行相应的处理,比如:判断用户是否登陆,记录日志信息等

SpringBoot添加拦截器的方法

1、定义拦截器

package com.test.util;

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

import org.springframework.stereotype.Component;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;

@Component
public class MyInterceptor implements HandlerInterceptor{

	@Override
	public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)
			throws Exception {
		System.out.println("MyInterceptor preHandle request..."+request);
		return true;
	}

	@Override
	public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler,
			ModelAndView modelAndView) throws Exception {
		System.out.println("MyInterceptor postHandle request..."+request);
		
	}

	@Override
	public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex)
			throws Exception {
		System.out.println("MyInterceptor afterCompletion request..."+request);
	}

}

2、配置拦截器

package com.test.util;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.SpringBootConfiguration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurerAdapter;

@SpringBootConfiguration
public class MySpringConfig extends WebMvcConfigurerAdapter{
	@Autowired
	private MyInterceptor myIntcpt;
	
	@Override
	public void addInterceptors(InterceptorRegistry registry)
	{
		registry.addInterceptor(myIntcpt).addPathPatterns("/**");
	}
}

日志信息

2018-12-18 21:32:29.866 DEBUG 18168 --- [nio-6060-exec-9] c.t.mapper.OrgModelMapper.getChildFunc   : ==> Parameters: 6(Integer)
2018-12-18 21:32:29.884 DEBUG 18168 --- [nio-6060-exec-9] c.t.mapper.OrgModelMapper.getChildFunc   : <==      Total: 0
2018-12-18 21:32:29.887 DEBUG 18168 --- [nio-6060-exec-9] c.t.mapper.OrgModelMapper.getChildFunc   : ==>  Preparing: select * from T_FUNCTION where parentid=? order by priority 
2018-12-18 21:32:29.887 DEBUG 18168 --- [nio-6060-exec-9] c.t.mapper.OrgModelMapper.getChildFunc   : ==> Parameters: 5(Integer)
2018-12-18 21:32:29.891 DEBUG 18168 --- [nio-6060-exec-9] c.t.mapper.OrgModelMapper.getChildFunc   : <==      Total: 0
MyInterceptor postHandle request...org.apache.catalina.connector.RequestFacade@5a31e8a0
MyInterceptor afterCompletion request...org.apache.catalina.connector.RequestFacade@5a31e8a0
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值