在Spring Boot中使用拦截器可以通过以下步骤实现:
HandlerInterceptor
接口。该接口包含了三个方法:preHandle
、postHandle
和afterCompletion
,分别在请求处理之前、请求处理之后和请求完成之后执行。import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class MyInterceptor implements HandlerInterceptor {
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
// 在请求处理之前执行的逻辑
return true; // 返回true表示继续执行请求,返回false表示中断请求
}
@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 {
// 在请求完成之后执行的逻辑,可用于资源清理等操作
}
}
addInterceptors
方法来注册拦截器。import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
@Configuration
public class WebConfig implements WebMvcConfigurer {
@Override
public void addInterceptors(InterceptorRegistry registry) {
registry.addInterceptor(new MyInterceptor()).addPathPatterns("/**");
}
}
上述代码中,addPathPatterns("/**")
表示拦截所有请求。
order
方法来指定它们的执行顺序。@Configuration
public class WebConfig implements WebMvcConfigurer {
@Override
public void addInterceptors(InterceptorRegistry registry) {
registry.addInterceptor(new MyInterceptor()).addPathPatterns("/**").order(1);
registry.addInterceptor(new AnotherInterceptor()).addPathPatterns("/**").order(2);
}
}
在上述示例中,MyInterceptor
的执行顺序为1,AnotherInterceptor
的执行顺序为2。
preHandle
方法中进行身份验证、日志记录等操作。@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
// 身份验证逻辑示例
String token = request.getHeader("Authorization");
if (token == null || !token.equals("valid_token")) {
response.setStatus(HttpServletResponse.SC_UNAUTHORIZED);
return false; // 中断请求
}
return true; // 继续执行请求
}
以上就是在Spring Boot中使用拦截器的基本步骤。请注意,这只是一个简单的示例,实际应用中可能需要根据具体需求进行适当的修改和扩展。
领取专属 10元无门槛券
手把手带您无忧上云