在项目上线后,接口调用时系统报错:
Could not initialize class net.sf.cglib.beans.BeanCopier java.lang.NoClassDefFoundError: Could not initialize class net.sf.cglib.beans.BeanCopier
登录跳板机查看详细日志,看到下面的详细报错:
java.lang.IncompatibleClassChangeError: class net.sf.cglib.core.DebuggingClassWriter has interface org.objectweb.asm.ClassVisitor as super class
项目中使用的 cglib 版本为 3.2.9, asm 版本为 3.1。
根据报错是 ClassVisitor 的父类不相容,我们看下 cglib 3.2.9 版本的定义:
public class DebuggingClassWriter extends ClassVisitor {
}
既然用 extends 关键字,ClassVisitor 必然是实现类或抽象类,但我们看 asm 3.1 版本中 ClassVisitor 是 interface。
这很容易看出是 asm 和 cglib 版本不一致导致 ClassVisitor 初始化错误。
解决方案有两种:
1)把 cglib 版本降低到 2.2 版本,此时 ClassVisitor 的实现:
// ClassWriter 是抽象类
public class DebuggingClassWriter extends ClassWriter {
}
2)把 asm 版本升高到 ClassVisitor 为抽象类,我看到 5.0.4 版本符合这个条件。
注:本文使用第一种方案,方案二从理论上看是可行的,可能会引入其他问题,使用需谨慎验证。