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