spring boot 拦截器获取controller返回的数据_@RestController vs @Controller
时间: 2023-08-03 22:55:53 浏览: 339
在Spring Boot中,拦截器可以用于在请求到达Controller之前或之后执行某些操作。无论是@RestController还是@Controller,拦截器都可以获取到Controller的返回值。
但是,对于@RestController和@Controller的区别,需要注意以下两点:
1.返回值类型不同
- @RestController注解的Controller方法返回的是JSON/XML等数据,适用于API接口的开发。
- @Controller注解的Controller方法返回的是视图(View),适用于Web页面的开发。
2.@RestController注解相当于@ResponseBody + @Controller
- @RestController注解会自动将Controller方法返回的数据转换为JSON/XML等格式的数据,并将其输出到响应体中,不需要使用@ResponseBody注解。
- @Controller注解需要使用@ResponseBody注解才能将数据输出到响应体中。
因此,在拦截器中获取Controller返回值时,需要根据Controller的注解类型进行不同的处理。如果是@RestController,直接获取响应体中的数据即可;如果是@Controller,则需要获取ModelAndView对象并从中获取数据。
相关问题
spring boot拦截器过滤器
Spring Boot中的拦截器和过滤器有一些区别。拦截器是Spring MVC自带的,不依赖于servlet容器,而过滤器依赖于servlet容器。拦截器是基于Java的反射机制,而过滤器是基于函数的回调。拦截器只能对action请求起作用,而过滤器可以对几乎所有的请求起作用。拦截器可以获取IOC容器中的bean,而过滤器不可以。拦截器是由Spring MVC提供的,可以在Controller中访问服务层。而过滤器是JavaEE标准,只需依赖servlet API,不需要依赖Spring。在Spring Boot中配置拦截器可以使用@WebFilter注解,并在启动类中加上@ServletComponentScan注解指定扫描的包。\[1\]\[2\]\[3\]
#### 引用[.reference_title]
- *1* [Springboot--拦截器、过滤器 区别,作用,实现方法](https://blog.csdn.net/Dark_AK44/article/details/123746613)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item]
- *2* *3* [springboot过滤器和拦截器](https://blog.csdn.net/qq_42076204/article/details/125215984)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item]
[ .reference_list ]
如何为Spring Boot项目的特定Controller添加自定义拦截器?
在Spring Boot项目中,你可以通过配置全局或具体的Controller级别的AOP(面向切面编程)来添加自定义拦截器。以下是一般的步骤:
1. **创建自定义拦截器类**:首先,创建一个实现了`HandlerInterceptor`接口的类,例如`MyCustomInterceptor`。这个接口有几个默认方法,如preHandle(), postHandle(), 和afterCompletion(),你可以根据需要覆盖其中的方法来定制拦截行为。
```java
import org.springframework.web.servlet.HandlerInterceptor;
public class MyCustomInterceptor implements HandlerInterceptor {
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
// 在请求处理前执行的操作
return true; // 如果你想继续处理请求,则返回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 {
// 异常处理或请求完成后执行的操作
}
}
```
2. **应用到Spring MVC**:接下来,在你的Spring Boot应用的配置类(通常是`Application.java`或`WebMvcConfigurerAdapter`的子类)中注册你的拦截器。可以使用`addInterceptors()`方法来添加全局拦截器,也可以使用`addMethodInterceptor()`方法针对特定的Controller。
```java
@Configuration
public class WebConfig implements WebMvcConfigurer {
private final MyCustomInterceptor myCustomInterceptor;
public WebConfig(MyCustomInterceptor myCustomInterceptor) {
this.myCustomInterceptor = myCustomInterceptor;
}
@Override
public void addInterceptors(InterceptorRegistry registry) {
registry.addInterceptor(myCustomInterceptor).addPathPatterns("/**"); // 全局拦截所有请求
// 或者更具体地针对某个Controller
registry.addInterceptor(myCustomInterceptor).addPathPatterns("/mySpecialController/**");
}
}
```
阅读全文