帮朋友解决一个问题,spring boot序列化对象回去的时候报错,排查出原因,项目中引入了一个第三方支付的jar包,这个包中自己建了一个jackson的包,第一反应是其中代码不全或者版本和当前boot项目的版本不匹配,导致序列化报找不到方法的错误。
据反映在开发环境使用springboot的模式main方法启动是ok的,但是打成war包丢到tomcat里以后就不行了,笔者反应是,springboot有自己的一套jar和类加载方式,至于tomcat又是另一样,事实证明查阅资料后确实如此,读者有兴趣可以百度或者google一下两种方式的不同加载模式,boot的加载隔离方面做的很好,下面说解决方案。
- 是直接将jar中的jackson代码全部删除掉,然后把jar重新丢到项目中,这样就不会出现加载冲突的问题,重点在2
2. 将gateway-client jar包名改成 zzzz-gateway-client ,因为tomcat中jar包的加载方式是通过文件名的大小排序来加载的 例如 A、B、C … Z ,
按照顺序是先加载A包,再加载B包,依次类推,最后加载Z包,那么每次加载过一个包名后,后面再碰到相同的包名的时候,他就不会再去加载了,
所以把这个第三方jar放到最后,tomcat就不会去加载和之前jar包有冲突的包,这样就解决了问题,
注意不会加载的包指的是jar文件夹下的 alibaba , jcraft 这种包,如果只是alibaba的冲突了,不影响它继续加载jcraft这个包以及class,jar就相当一个压缩文件,实施类加载的时候其实是将jar解压,然后加载里面的class的。