为什么阿里巴巴禁止接口返回值用枚举?

返回枚举类型

最近在用别的项目提供的jar包,由于对方的更新导致原本没问题的接口返回了下面的错误:

mark

这个接口是我feign调用别的项目,从报错信息可以看到是因为json反序列化失败,枚举类不一致导致的。

原因是:两方引用了共同的common jar包,升级之后,那边引用了新的,返回了新的枚举类型,我这边没升级导致的。

这个问题虽然后续通过引用新jar解决了,但是我记得在阿里开发规范内不允许在返回类内用枚举,然后果然找到了这一条:

mark

哎,但是无奈对方,嗯~ o( ̄▽ ̄)o

序列化is方法

然后,前面的问题解决了,调用之后又爆了一个bug:

截图找不到了~~

具体就是又找不到一个属性,然后反编译类查看jar包确实没有这个属性,然后在类里面搜索这个属性,结果发现了这个方法:

isSuccess();

(╯‵□′)╯︵┻━┻

mark

然后我为了确认,还写了个demo,

mark

来,我们看下源码:

mark

因为我们是is方法序列化的问题,所以进到_addMethod()方法

可以看到循环了6个方法,进到_addGetterMethod方法内

mark

mark

mark

到这里就可以看到为什么is开头而且是boolean类型了

tips:

jackson针对这个其实是有一个配置来关闭此类场景

mapper.configure(MapperFeature.AUTO_DETECT_IS_GETTERS, false);

mark

总结:请提高自身能力,减少周围的傻X

posted @ 2019-03-04 10:08  phycho  阅读(6043)  评论(19编辑  收藏  举报