问题背景:做了一个demo学习CGLIB动态代理,由于只学习单个知识点,就没有使用Maven依赖管理工具,而是直接导入依赖的方式,其中两个依赖的版本为,asm-5.0.4.jar和cglib-3.3.0.jar,就报了以下的错误,由于没有明确性的提示,不知道报错地方在哪里,但是可以根据调用栈的顺序去判断出现异常的大概位置;
首先是最低部的位置,可以知道是调用了Enhance方法开始
at net.sf.cglib.proxy.Enhancer.<clinit>(Enhancer.java:73)
直到出现异常抛出的位置:可以看出at org.objectweb.asm.ClassVisitor和net.sf.cglib.proxy.Enhancer是两个不同的依赖,根据报错异常(IllegalArgumentException)那么就可以大概猜出,两者匹配的版本可能存在关系对应
Caused by: java.lang.IllegalArgumentException
at org.objectweb.asm.ClassVisitor.<init>(Unknown Source)
Exception in thread "main" java.lang.ExceptionInInitializerError
at com.catt.CglibProxy.getProxyInstance(CglibProxy.java:26)
at com.catt.App.main(CglibProxy.java:48)
Caused by: java.lang.IllegalArgumentException
at org.objectweb.asm.ClassVisitor.<init>(Unknown Source)
at net.sf.cglib.core.DebuggingClassWriter.<init>(DebuggingClassWriter.java:49)
at net.sf.cglib.core.DefaultGeneratorStrategy.getClassVisitor(DefaultGeneratorStrategy.java:30)
at net.sf.cglib.core.DefaultGeneratorStrategy.generate(DefaultGeneratorStrategy.java:24)
at net.sf.cglib.core.AbstractClassGenerator.generate(AbstractClassGenerator.java:332)
at net.sf.cglib.core.AbstractClassGenerator$ClassLoaderData$3.apply(AbstractClassGenerator.java:96)
at net.sf.cglib.core.AbstractClassGenerator$ClassLoaderData$3.apply(AbstractClassGenerator.java:94)
at net.sf.cglib.core.internal.LoadingCache$2.call(LoadingCache.java:54)
at java.util.concurrent.FutureTask.run$$$capture(FutureTask.java:266)
at java.util.concurrent.FutureTask.run(FutureTask.java)
at net.sf.cglib.core.internal.LoadingCache.createEntry(LoadingCache.java:61)
at net.sf.cglib.core.internal.LoadingCache.get(LoadingCache.java:34)
at net.sf.cglib.core.AbstractClassGenerator$ClassLoaderData.get(AbstractClassGenerator.java:119)
at net.sf.cglib.core.AbstractClassGenerator.create(AbstractClassGenerator.java:294)
at net.sf.cglib.core.KeyFactory$Generator.create(KeyFactory.java:221)
at net.sf.cglib.core.KeyFactory.create(KeyFactory.java:174)
at net.sf.cglib.core.KeyFactory.create(KeyFactory.java:153)
at net.sf.cglib.proxy.Enhancer.<clinit>(Enhancer.java:73)
... 2 more
Disconnected from the target VM, address: '127.0.0.1:56864', transport: 'socket'
问题解决:根据这个思路,可以在maven仓库里选下载Cglib依赖,查看自带的asm版本即可。如下图可得,于是换上对应的版本,问题解决。
asm-4.2.jar和cglib-3.1.jar