Java Interceptor中使用HttpServletRequest

本文详细介绍了在SpringMVC中如何通过在web.xml中添加listener来处理请求,并展示了如何在interceptor中注入HttpServletRequest。同时,对于SpringBoot环境下,讲解了如何在interceptor中获取HttpServletRequest,通过RequestAttributes和RequestContextHolder实现。

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

  • SpringMvc中
  1. web.xml 添加listener
	<listener>
        <listener-class>org.springframework.web.context.request.RequestContextListener</listener-class>
    </listener>
  1. interceptor中注解注入request即可
    @Autowired
    HttpServletRequest request;

` SpringBoot中
intercepter中需要使用的地方直接插入

RequestAttributes requestAttributes = RequestContextHolder.getRequestAttributes();
HttpServletRequest request = (HttpServletRequest) requestAttributes.resolveReference(RequestAttributes.REFERENCE_REQUEST);
### 如何使用拦截器 (Interceptor) #### 实现 HandlerInterceptor 接口 为了创建一个自定义的拦截器,在 Spring Boot 应用程序中通常需要实现 `HandlerInterceptor` 接口。此接口提供了三个主要的方法来控制请求的不同阶段: - **preHandle**: 请求处理前被调用,返回 true 则继续流程;false 将中断后续操作。 - **postHandle**: 请求处理器完成执行后但在视图渲染之前调用。 - **afterCompletion**: 整个请求结束之后调用。 ```java import org.springframework.web.servlet.HandlerInterceptor; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; public class MyCustomInterceptor implements HandlerInterceptor { @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { System.out.println("Before handling the request"); return true; // Continue with next interceptors or target method. } @Override public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception { System.out.println("After processing but before rendering view"); } @Override public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception { System.out.println("Request has been completed."); } } ``` #### 注册拦截器到 WebMvcConfigurer 为了让应用程序知道新创建的拦截器的存在,还需要将其注册至配置类中。这可以通过扩展 `WebMvcConfigurer` 并重写相应的方法来完成。 ```java 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 AppConfig implements WebMvcConfigurer { private final MyCustomInterceptor myCustomInterceptor; public AppConfig(MyCustomInterceptor myCustomInterceptor){ this.myCustomInterceptor = myCustomInterceptor; } @Override public void addInterceptors(InterceptorRegistry registry) { registry.addInterceptor(myCustomInterceptor).addPathPatterns("/api/**"); // Apply to all API endpoints under /api/ } } ``` #### 配置静态资源路径排除 有时可能不希望某些类型的请求受到拦截影响,比如加载 CSS 文件或其他前端依赖项时。这时可以指定要忽略的具体 URL 模式。 ```java @Override public void addResourceHandlers(ResourceHandlerRegistry registry) { registry.addResourceHandler("/static/**").addResourceLocations("classpath:/static/"); } // In addition to adding resource handlers... @Override public void addInterceptors(InterceptorRegistry registry) { registry.addInterceptor(new MyCustomInterceptor()) .excludePathPatterns("/static/**", "/css/**", "/js/**", "/images/**"); } ``` #### 用户会话状态检查 在许多情况下,开发者可能会利用拦截器来进行身份验证或授权检查。下面的例子展示了如何基于用户会话信息做出决策。 ```java @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { HttpSession session = request.getSession(false); if(session != null && session.getAttribute("user") != null){ return true; }else{ response.sendRedirect("/login"); return false; } } ``` #### 条件化取消拦截行为 根据具体的业务需求,也可以有条件地跳过某个特定路径下的拦截动作。例如只针对 POST 方法实施额外的安全措施。 ```java if ("POST".equalsIgnoreCase(request.getMethod()) && !request.getRequestURI().startsWith("/admin/")) { // Perform additional checks here and decide whether to proceed. } else { return super.preHandle(request, response, handler); } ``` 以上就是有关于如何在 Spring Boot 中设置和运用拦截器的一个基本介绍[^1]。除了上述提到的功能外,拦截器还能够用于其他多种场景下增强应用的行为,如日志记录、性能监控等[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值