前言
在前后端分离的项目中,前端与后台一般会约定好固定的参数和响应的数据结构,如:
参数:
1 | java复制代码public class ApiRequest<T> { |
响应:
1 | java复制代码public class ApiResult<T> { |
一般传统的做法是在 Controller
层方法直接接收ApiRequest
参数和直接返回ApiResult
的实例:
- 在参数中传入
ApiRequest
对象,然后手动获取业务参数data
进行处理 - 每个接口手动生成
ApiResult
对象并返回。
这一部分工作其实是重复也无太多意义的,那么有没有一种方法可以自动做到 我们只关注 ApiRequest.data
和 ApiResult.data
,让程序自动将参数传入到 业务参数data
中和 控制层方法只返回 data
,程序自动封装成ApiResult
并返回呢?那么今天的主人公 RequestBodyAdvice
,ResponseBodyAdvice
就登场了。
RequestBodyAdvice
RequestBodyAdvice
是SpringMVC
4.2提供的一个接口,它允许请求体被读取并转换为对象,并将处理结果对象作为@RequestBody
参数或者 @HttpEntity
方法参数。由此可见,它的作用范围为:
- 使用
@RequestBody
进行标记的参数 - 参数为
HttpEntity
提供的方法
1 | java复制代码boolean supports(MethodParameter methodParameter, Type targetType, |
该方法返回true
时,才会进去下面的系列方法
1 | java复制代码HttpInputMessage beforeBodyRead(HttpInputMessage inputMessage, MethodParameter parameter, |
body数据读取之前调用,一般在此方法中对body数据进行修改
1 | java复制代码Object afterBodyRead(Object body, HttpInputMessage inputMessage, MethodParameter parameter, |
body读取之后操作,一般直接返回原实例
1 | java复制代码Object handleEmptyBody(@Nullable Object body, HttpInputMessage inputMessage, MethodParameter parameter, |
当body问empty时操作
实现步骤
- 编写一个实现类实现
RequestBodyAdvice
接口 - 分别实现对应的方法
- 实现类上添加注解标记:
ControllerAdvice
实例
1 | java复制代码@ControllerAdvice |
上面实例中,supports
添加了支持条件:当控制层方法或者类上有标记注解 @RequestAdvice
注解时,才会进入其他相关方法。当不需要任何限制时,supports
直接返回true
即可。
ResponseBodyAdvice
ResponseBodyAdvice
是SpringMVC
4.1提供的一个接口,它允许在 执行 @ResponseBody
后自定义返回数据,或者将返回@ResponseEntity
的 Controller Method
在写入主体前使用 HttpMessageConverter
进行自定义操作。由此可见,它的作用范围为:
- 使用
@ResponseBody
注解进行标记 - 返回
@ResponseEntity
提供的方法
1
java复制代码boolean supports(MethodParameter returnType, Class<? extends HttpMessageConverter<?>> converterType);
该方法返回true
时,才会进去下面的 beforeBodyWrite
方法。该方法可以添加一些判断条件,比如 方法上有 xxx 注解的才会生效等等。
1
2
3java复制代码T beforeBodyWrite(@Nullable T body, MethodParameter returnType, MediaType selectedContentType,
Class<? extends HttpMessageConverter<?>> selectedConverterType,
ServerHttpRequest request, ServerHttpResponse response);
body写入前的操作。
实现步骤
- 编写一个实现类实现
ResponseBodyAdvice
接口 - 重写
supports
和boforeBodyWrite
- 实现类上添加注解标记:
ControllerAdvice
实例
1 | java复制代码@ControllerAdvice |
上面实例中,supports
添加了支持条件:当控制层方法或者类上有标记注解 @ResponseAdvice
直接时,才会进入beforeBodyWrite
方法。当不需要任何限制时,supports
直接返回true
即可。
其他
上述只是针对 公共参数、公共返回这一种情况对 RequestBodyAdvice
、ResponseBodyAdvice
进行了说明,当然这两种接口不止这一种应用场景,比如对参数或者返回进行加解密都可以使用这两种接口进行实现。具体使用场景用户可根据实际情况进行使用。
本文转载自: 掘金