SpringBoot源码分析系列之三:拦截器的优雅实现

引言

所谓拦截器即为可以拦截HTTP请求的并做一些前置或者后置的通用处理手段,是一种AOP的处理方式,它不依赖于servlet容器,而依赖于web框架SpringMVC。主要用于拦截controller的请求接口。

  • 基于URL实现拦截器
  • 基于注解实现拦截器

一、基于URL实现拦截器

首先说明下基于URL的拦截器实现方式,具体代码如下所示,它主要完成的功能是对除了/cs结尾之外的其他请求都进行token有效性的验证,只有header中带有有效token信息的请求才会被转发到具体的controller接口中。

public class TokenInterceptor implements HandlerInterceptor {
	
	/**
	 * Handler执行之前调用此方法
	 */
	@Override
	public boolean preHandle(HttpServletRequest request,
			HttpServletResponse response, Object handler) throws Exception {


		String url = request.getRequestURL().toString();
		if(url.endsWith(PropertiesConstants.EV_CONTEXT+"/cs")){  //websocket连接不拦截
			return true;
		}
		// 验证header里的token是否合法
		String token = request.getHeader("Token");
		if (StringUtils.isEmpty(token)) {
			return false;
		}
		boolean bool = TokenUtils.isTokenValid(token);		
		if (bool) {
				return true;
		} else {
			return false;
		}

	}

	/**
	 * Handler执行之后,ModelAndView返回之前调用这个方法
	 */
	@Override
	public void postHandle(HttpServletRequest request,
			HttpServletResponse response, Object handler,
			ModelAndView modelAndView) throws Exception {

	}

	/**
	 * Handler执行完成之后调用这个方法
	 */
	@Override
	public void afterCompletion(HttpServletRequest request,
			HttpServletResponse response, Object handler, Exception ex)
			throws Exception {
	}
}

注意在springMVC.xml中将对应的拦截器进行配置。

<mvc:interceptors>
		<mvc:interceptor>
			<mvc:mapping path="/**/*" />
			<bean class="com.tms.TokenInterceptor"></bean>
		</mvc:interceptor>
	</mvc:interceptors>

二、基于注解实现拦截器

1、创建注解

/**
是否需要进行登录验证
*/
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface LoginHandler {

	
}

2、创建登录拦截器

public class LoginInterceptor implements HandlerInterceptor {

	static Logger logger = LoggerFactory.getLogger(LoginInterceptor.class);
	
	@Override
	public boolean preHandle(HttpServletRequest request,
			HttpServletResponse response, Object handler) throws Exception {
		logger.info(">>>LoginInterceptor>>>>>>>在请求处理之前进行调用(Controller方法调用之前)");
		//获取方法级别注解
        HandlerMethod handlerMethod = (HandlerMethod) handler;
        Method method = handlerMethod.getMethod();
        LoginHandler loginHandler = method.getAnnotation(LoginHandler.class);
        //判断是否需要进行登录验证
        if (null != loginHandler) {
        	//TODO : 具体的实现
        	return true;
		}
		return true;
	}

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

	}

	@Override
	public void afterCompletion(HttpServletRequest request,
			HttpServletResponse response, Object handler, Exception ex)
			throws Exception {

	}

}

3、排至拦截器,将其注入容器中

@Configuration
public abstract class WebConfigurer implements WebMvcConfigurer{

	 @Override
	 public void addInterceptors(InterceptorRegistry registry) {
        // 拦截所有请求,通过判断是否有 @LoginRequired 注解 决定是否需要登录
        registry.addInterceptor(LoginInterceptor()).addPathPatterns("/**");
	 }
	 
	 @Bean
	 public LoginInterceptor LoginInterceptor() {
		 return new LoginInterceptor();
	 }


}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

慕枫技术笔记

您的鼓励是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值