我们部署一个新项目,实际上就是在旧的项目上的一个修改,添加一些新的东西和修复一些问题。但是在部署服务器打包后,服务也能正常去启动的情况下,发现某个功能报错报系统错误,发现后台日志的报错是
Caused by: java.lang.NoSuchMethodError: cn.hutool.XXXXX
一般来说这种可能是包冲入导致的,于是借助idea插件maven-helper看一下是否有对应的冲突。但是问题来了,项目冲突是有的,但是没找到对应的xxxxx.实际上看图上知道,这是一个工具类的包,按理来说应该没什么问题,旧的系统跑着都没问题,这maven helper也没有对应冲突展示。
想了一下,可能这次不能借助工具了。
首先找到报错的地方:
org.springframework.web.util.NestedServletException: Handler dispatch failed; nested exception is java.lang.NoSuchMethodError: cn.hutool.core.bean.BeanUtil.beanToMap(Ljava/lang/Object;)Ljava/util/Map;
at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1055)
at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:943)
at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1006)
at org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:909)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:660)
at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:883)
重点就是这个cn.hutool.core.bean.BeanUtil.beanToMap这个方法找不到,一般来说都是同名类的导致的,所以搜索的是cn.hutool.core.bean.BeanUtil这个类名
cn.hutool.core.bean.BeanUtil
全文查找如下图
问题找到了,那就要去解决它。解决的方式也很简单就是exclud掉一个就可以了。
根据具体情况我这里要exclude的是hutool-all这个,但是他这个比较有意思的是他是通过external-weixin第三方包引进过来的,你用maven helper这些工具他会要去对应父文件eclude去,但这肯定是不行的如果是第三方包的pom文件。即热工具不行那就手工修改exclude对应的pom文件。
找到引入external-weixin的地方,做如下修改
<exclusions>
<exclusion>
<groupId>cn.hutool</groupId>
<artifactId>hutool-all</artifactId>
</exclusion>
</exclusions>
实际上这个给groupid和artifactId可以通过我们查找的提示来来改,红框圈中的分别是对应的groupid和artifactId,天上就可以了