java.lang.NoSuchMethodError: org.springframework.util.StringUtils.isEmpty的bug事件的记录

java.lang.NoSuchMethodError: org.springframework.util.StringUtils.isEmpty的bug事件的记录

在某次启动服务器的时候出现这个bug,之前都没有出现这样的bug。解决良久,问了大佬才知道。

String-core里面StringUtil这个类是没有isEmpty这个方法的,但是activemq-all这个jar里面的StringUtil有isEmpty这个方法。

最最重要的是上面两个StringUtil的路径都是一样的。都是org.springframework.util。

也就是说,jvm在加载的时候根本不能区分自己加载的StringUtil是来自哪个包,因为路径都是org.springframework.util.SpringUtil。

所以有时候能启动,有时候不能启动是因为碰运气看jvm先加载了哪个类,如果是加载了有isEmpty方法的StringUtil的类就一切ok。

最后,下次出现同样的问题怎么办?

如果使用的是idea的话,点击ctrl+n+你要查询的类,就可以查看到你想查询的类在多少jar包中出现过,然后你就可以观察路径是否重复了导致jvm加载了你不想要的类。如果确实是加载了你不想要的类,为了防止这种时好时不好的情况,建议那个类去掉,比如通过pom文件<exclusion>去掉某些包来去掉那个类。

感觉这个问题也是很多jar包冲突的原因吧