360SDN.COM

首页/Java/列表

异常解决java.io.IOException: invalid constant type: 15

来源:  2019-03-04 11:20:02    评论:0点击:

最近一个项目测试的时候,需要进行多个tomcat集群测试。 我本地用了一个新的tomcat, 然后把项目打好的war包扔到tomcat里面进行运行。 启动时出现一个异常:java.io.IOException: invalid constant type: 15 。

解决办法:javassist替换到3.18.1版本以上,问题解决。

项目启动环境:jdk1.8 , tomcat8

网上查阅资料,说是引用dubbo 2.8版本时,自动引用了javassist 3.15.0版本。 导致和jdk的javassist冲突。 查看maven 的pom.xml文件,有引入javassist 3.21.0版本。 但是并没有3.15.0版本。 
解决步骤:
一、输出maven依赖的树,并输出日志到指定文件
然后在项目的pom.xml文件目录,打开CMD 环境, 执行命令 mvn dependency:tree>2.txt

二、查看2.txt文件,看到项目所有的jar的依赖树。
里面就包括了dubbo里面引用了javassist 3.15.0 具体操作如下图:

然后就到依赖dubbo的maven配置那里,排除javassist的依赖。 具体如下:
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>dubbo</artifactId>
<version>2.8.4</version>
<exclusions>
<exclusion><artifactId>javassist</artifactId><groupId>org.javassist</groupId></exclusion>
</exclusions>
</dependency>

这里大家自己的格式是什么样的就自己格式化一下。然后重新编译,更新下maven。 问题解决。(其他jar依赖冲突的问题也可以这样分析解决)

如果这样配置了还没解决。去看下2.txt文件还有没有其他关于javassist的依赖。一并去除。 另外就是找到你所依赖的项目的本地仓库,找到依赖项目的版本,清除,重新install。 解决!




严重: Exception sending context initialized event to listener instance of class org.springframework.web.context.ContextLoaderListener
java.lang.RuntimeException: java.io.IOException: invalid constant type: 18
 at javassist.CtClassType.getClassFile2(CtClassType.java:204)
 at javassist.CtClassType.subtypeOf(CtClassType.java:304)
 at javassist.CtClassType.subtypeOf(CtClassType.java:319)
 at javassist.compiler.MemberResolver.compareSignature(MemberResolver.java:248)
 at javassist.compiler.MemberResolver.lookupMethod(MemberResolver.java:120)
 at javassist.compiler.MemberResolver.lookupMethod(MemberResolver.java:97)
 at javassist.compiler.TypeChecker.atMethodCallCore(TypeChecker.java:711)
 at javassist.compiler.TypeChecker.atCallExpr(TypeChecker.java:688)
 at javassist.compiler.JvstTypeChecker.atCallExpr(JvstTypeChecker.java:157)
 at javassist.compiler.ast.CallExpr.accept(CallExpr.java:46)
 at javassist.compiler.CodeGen.doTypeCheck(CodeGen.java:242)
 at javassist.compiler.CodeGen.atStmnt(CodeGen.java:330)
 at javassist.compiler.ast.Stmnt.accept(Stmnt.java:50)
 at javassist.compiler.CodeGen.atStmnt(CodeGen.java:351)
 at javassist.compiler.ast.Stmnt.accept(Stmnt.java:50)
 at javassist.compiler.CodeGen.atIfStmnt(CodeGen.java:391)
 at javassist.compiler.CodeGen.atStmnt(CodeGen.java:355)
 at javassist.compiler.ast.Stmnt.accept(Stmnt.java:50)
 at javassist.compiler.CodeGen.atStmnt(CodeGen.java:351)
 at javassist.compiler.ast.Stmnt.accept(Stmnt.java:50)
 at javassist.compiler.MemberCodeGen.atTryStmnt(MemberCodeGen.java:204)
 at javassist.compiler.CodeGen.atStmnt(CodeGen.java:367)
 at javassist.compiler.ast.Stmnt.accept(Stmnt.java:50)
 at javassist.compiler.CodeGen.atStmnt(CodeGen.java:351)
 at javassist.compiler.ast.Stmnt.accept(Stmnt.java:50)
 at javassist.compiler.CodeGen.atMethodBody(CodeGen.java:292)
 at javassist.compiler.CodeGen.atMethodDecl(CodeGen.java:274)
 at javassist.compiler.ast.MethodDecl.accept(MethodDecl.java:44)
 at javassist.compiler.Javac.compileMethod(Javac.java:169)
 at javassist.compiler.Javac.compile(Javac.java:95)
 at javassist.CtNewMethod.make(CtNewMethod.java:74)
 at javassist.CtNewMethod.make(CtNewMethod.java:45)
 at com.alibaba.dubbo.common.bytecode.ClassGenerator.toClass(ClassGenerator.java:318)
 at com.alibaba.dubbo.common.bytecode.Wrapper.makeWrapper(Wrapper.java:346)
 at com.alibaba.dubbo.common.bytecode.Wrapper.getWrapper(Wrapper.java:89)
 at com.alibaba.dubbo.config.ServiceConfig.doExportUrlsFor1Protocol(ServiceConfig.java:426)
 at com.alibaba.dubbo.config.ServiceConfig.doExportUrls(ServiceConfig.java:281)
 at com.alibaba.dubbo.config.ServiceConfig.doExport(ServiceConfig.java:242)
 at com.alibaba.dubbo.config.ServiceConfig.export(ServiceConfig.java:143)
 at com.alibaba.dubbo.config.spring.ServiceBean.onApplicationEvent(ServiceBean.java:109)
 at org.springframework.context.event.SimpleApplicationEventMulticaster.multicastEvent(SimpleApplicationEventMulticaster.java:96)
 at org.springframework.context.support.AbstractApplicationContext.publishEvent(AbstractApplicationContext.java:334)
 at org.springframework.context.support.AbstractApplicationContext.finishRefresh(AbstractApplicationContext.java:948)
 at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:482)
 at org.springframework.web.context.ContextLoader.configureAndRefreshWebApplicationContext(ContextLoader.java:389)
 at org.springframework.web.context.ContextLoader.initWebApplicationContext(ContextLoader.java:294)
 at org.springframework.web.context.ContextLoaderListener.contextInitialized(ContextLoaderListener.java:112)
 at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:5016)
 at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5528)
 at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
 at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1575)
 at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1565)
 at java.util.concurrent.FutureTask.run(FutureTask.java:266)
 at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
 at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
 at java.lang.Thread.run(Thread.java:745)
Caused by: java.io.IOException: invalid constant type: 18
 at javassist.bytecode.ConstPool.readOne(ConstPool.java:1113)
 at javassist.bytecode.ConstPool.read(ConstPool.java:1056)
 at javassist.bytecode.ConstPool.<init>(ConstPool.java:150)
 at javassist.bytecode.ClassFile.read(ClassFile.java:765)
 at javassist.bytecode.ClassFile.<init>(ClassFile.java:109)
 at javassist.CtClassType.getClassFile2(CtClassType.java:191)
... 55 more
二、解决步骤

1. 根据异常日志中dubbo调用javassist编译字节码出错,定位javassist版本问题;

2. 由于同样的dubbo项目在jdk6下没有问题,当前项目使用的jdk8,所以应该是jdk8和javassist冲突;

3. 将dubbo引入的javassist-3.15.0-GA去掉,引入更高版本直到javassist-3.18.0-GA项目可以正常启动。

为您推荐

友情链接 |九搜汽车网 |手机ok生活信息网|ok生活信息网|ok微生活
 Powered by www.360SDN.COM   京ICP备11022651号-4 © 2012-2016 版权