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();
	 }


}

猜你喜欢

转载自blog.csdn.net/Diamond_Tao/article/details/85055294