2019独角兽企业重金招聘Python工程师标准>>>
最近在工作中遇到一个问题:我们正在开发的项目要求新版本以后的接口返回值要加密,并且要兼容以前老版本的接口(就是老版本接口不加密)。以前有个项目倒是有过类似的做法,使用的是aop实现。aop固然能够达到实现,但查看spring文档就会发现,spring早就为我们预留了实现接口,比aop更加方便。
spring的实现是ResponseBodyAdvice,顾名思义,请求返回值增强。
实现如下:
@ControllerAdvice(basePackages = "com.test")
public class EncryptResponseAdvice implements ResponseBodyAdvice<Object> {
@Override
public boolean supports(MethodParameter returnType, Class<? extends HttpMessageConverter<?>> converterType) {
return true;
}
@Override
public Object beforeBodyWrite(Object body, MethodParameter returnType,
MediaType selectedContentType, Class<? extends HttpMessageConverter<?>> selectedConverterType,
ServerHttpRequest request, ServerHttpResponse response) {
//先做版本判断,然后加密处理
return body;
}
}
ResponseBodyAdvice还可以实现jsonp,具体的类spring已经存在。
其实aop也完全可以实现,但既然spring已经提供了此功能,就最好用它的。不得不说,spring的扩展性还是挺强大的。