javassist异常处理: java.lang.RuntimeException: java.io.IOException: invalid constant type: 18

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/yunfeng482/article/details/88799147

javassist异常处理: java.lang.RuntimeException: java.io.IOException: invalid constant type: 18

异常描述:
在进行mock挡板测试时候,出现对应java应用快捷支付XX应用接入javaagent启动过程出现以下异常。经过网上错误定位,基本确认javassist的版本问题,可是看到agent工具包里的版本是Javassist 3.20.0-GA的,是支持jdk1.8的class修改,然后尝试升级了agent代理工具包的javassist源码版本,发现还是出现此错误。折腾了半天之后,忽略目标应用的classpath,检查到目标java应用启动jvm参数中看到应用也使用javassist依赖是javassist-3.8.0.GA.jar。后面经过沟通,将对方应用的javassist依赖更新到Javassist 3.20.0-GA,应用正常启动。


Load java/net/Socket
java.lang.RuntimeException: java.io.IOException: invalid constant type: 18
 at javassist.CtClassType.getClassFile2(CtClassType.java:203)
 at javassist.CtClassType.subtypeOf(CtClassType.java:303)
 at javassist.CtClassType.subtypeOf(CtClassType.java:318)
 at javassist.compiler.MemberResolver.compareSignature(MemberResolver.java:247)
 at javassist.compiler.MemberResolver.lookupMethod(MemberResolver.java:119)
 at javassist.compiler.MemberResolver.lookupMethod(MemberResolver.java:96)
 at javassist.compiler.TypeChecker.atMethodCallCore(TypeChecker.java:704)
 at javassist.compiler.TypeChecker.atNewExpr(TypeChecker.java:148)
 at javassist.compiler.ast.NewExpr.accept(NewExpr.java:72)
 at javassist.compiler.TypeChecker.atVariableAssign(TypeChecker.java:248)
 at javassist.compiler.TypeChecker.atAssignExpr(TypeChecker.java:217)
 at javassist.compiler.ast.AssignExpr.accept(AssignExpr.java:38)
 at javassist.compiler.CodeGen.doTypeCheck(CodeGen.java:241)
 at javassist.compiler.CodeGen.atStmnt(CodeGen.java:329)
 at javassist.compiler.ast.Stmnt.accept(Stmnt.java:49)
 at javassist.compiler.CodeGen.atStmnt(CodeGen.java:350)
 at javassist.compiler.ast.Stmnt.accept(Stmnt.java:49)
 at javassist.compiler.CodeGen.atIfStmnt(CodeGen.java:390)
 at javassist.compiler.CodeGen.atStmnt(CodeGen.java:354)
 at javassist.compiler.ast.Stmnt.accept(Stmnt.java:49)
 at javassist.compiler.CodeGen.atStmnt(CodeGen.java:350)
 at javassist.compiler.ast.Stmnt.accept(Stmnt.java:49)
 at javassist.compiler.MemberCodeGen.atTryStmnt(MemberCodeGen.java:203)
 at javassist.compiler.CodeGen.atStmnt(CodeGen.java:366)
 at javassist.compiler.ast.Stmnt.accept(Stmnt.java:49)
 at javassist.compiler.CodeGen.atStmnt(CodeGen.java:350)
 at javassist.compiler.ast.Stmnt.accept(Stmnt.java:49)
 at javassist.compiler.CodeGen.atIfStmnt(CodeGen.java:390)
 at javassist.compiler.CodeGen.atStmnt(CodeGen.java:354)
 at javassist.compiler.ast.Stmnt.accept(Stmnt.java:49)
 at javassist.compiler.CodeGen.atStmnt(CodeGen.java:350)
 at javassist.compiler.ast.Stmnt.accept(Stmnt.java:49)
 at javassist.compiler.Javac.compileStmnt(Javac.java:568)
 at javassist.CtBehavior.insertBefore(CtBehavior.java:658)
 at javassist.CtBehavior.insertBefore(CtBehavior.java:638)

此问题定位:
1、查看目标应用是否存在的javassist依赖,存在则检查该版本是否支持修改对应jdk版本的class。
2、查看javaagent的javassist依赖是否支持修改jdk版本的class

猜你喜欢

转载自blog.csdn.net/yunfeng482/article/details/88799147
今日推荐