使用nuwa热补丁的编译注入第三方jar类的问题

来源:互联网 发布:yum安装命令 编辑:程序博客网 时间:2024/05/21 14:52


使用nuwa热补丁编译时,使用javassist,在注入腾讯的jar的类时报一下问题:

* Exception is:org.gradle.api.tasks.TaskExecutionException: Execution failed for task ':sample:nuwaJarBeforeDexQihooDebug'.at org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter.executeActions(ExecuteActionsTaskExecuter.java:69)at org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter.execute(ExecuteActionsTaskExecuter.java:46)at org.gradle.api.internal.tasks.execution.PostExecutionAnalysisTaskExecuter.execute(PostExecutionAnalysisTaskExecuter.java:35)at org.gradle.api.internal.tasks.execution.SkipUpToDateTaskExecuter.execute(SkipUpToDateTaskExecuter.java:64)at org.gradle.api.internal.tasks.execution.ValidatingTaskExecuter.execute(ValidatingTaskExecuter.java:58)at org.gradle.api.internal.tasks.execution.SkipEmptySourceFilesTaskExecuter.execute(SkipEmptySourceFilesTaskExecuter.java:42)at org.gradle.api.internal.tasks.execution.SkipTaskWithNoActionsExecuter.execute(SkipTaskWithNoActionsExecuter.java:52)at org.gradle.api.internal.tasks.execution.SkipOnlyIfTaskExecuter.execute(SkipOnlyIfTaskExecuter.java:53)at org.gradle.api.internal.tasks.execution.ExecuteAtMostOnceTaskExecuter.execute(ExecuteAtMostOnceTaskExecuter.java:43)at org.gradle.api.internal.AbstractTask.executeWithoutThrowingTaskFailure(AbstractTask.java:310)at org.gradle.execution.taskgraph.AbstractTaskPlanExecutor$TaskExecutorWorker.executeTask(AbstractTaskPlanExecutor.java:79)at org.gradle.execution.taskgraph.AbstractTaskPlanExecutor$TaskExecutorWorker.processTask(AbstractTaskPlanExecutor.java:63)at org.gradle.execution.taskgraph.AbstractTaskPlanExecutor$TaskExecutorWorker.run(AbstractTaskPlanExecutor.java:51)at org.gradle.execution.taskgraph.DefaultTaskPlanExecutor.process(DefaultTaskPlanExecutor.java:23)at org.gradle.execution.taskgraph.DefaultTaskGraphExecuter.execute(DefaultTaskGraphExecuter.java:88)at org.gradle.execution.SelectedTaskExecutionAction.execute(SelectedTaskExecutionAction.java:37)at org.gradle.execution.DefaultBuildExecuter.execute(DefaultBuildExecuter.java:62)at org.gradle.execution.DefaultBuildExecuter.access$200(DefaultBuildExecuter.java:23)at org.gradle.execution.DefaultBuildExecuter$2.proceed(DefaultBuildExecuter.java:68)at org.gradle.execution.DryRunBuildExecutionAction.execute(DryRunBuildExecutionAction.java:32)at org.gradle.execution.DefaultBuildExecuter.execute(DefaultBuildExecuter.java:62)at org.gradle.execution.DefaultBuildExecuter.execute(DefaultBuildExecuter.java:55)at org.gradle.initialization.DefaultGradleLauncher.doBuildStages(DefaultGradleLauncher.java:149)at org.gradle.initialization.DefaultGradleLauncher.doBuild(DefaultGradleLauncher.java:106)at org.gradle.initialization.DefaultGradleLauncher.run(DefaultGradleLauncher.java:86)at org.gradle.launcher.exec.InProcessBuildActionExecuter$DefaultBuildController.run(InProcessBuildActionExecuter.java:90)at org.gradle.tooling.internal.provider.runner.BuildModelActionRunner.run(BuildModelActionRunner.java:54)at org.gradle.launcher.exec.ChainingBuildActionRunner.run(ChainingBuildActionRunner.java:35)at org.gradle.launcher.exec.InProcessBuildActionExecuter.execute(InProcessBuildActionExecuter.java:41)at org.gradle.launcher.exec.InProcessBuildActionExecuter.execute(InProcessBuildActionExecuter.java:28)at org.gradle.launcher.daemon.server.exec.ExecuteBuild.doBuild(ExecuteBuild.java:49)at org.gradle.launcher.daemon.server.exec.BuildCommandOnly.execute(BuildCommandOnly.java:36)at org.gradle.launcher.daemon.server.api.DaemonCommandExecution.proceed(DaemonCommandExecution.java:120)at org.gradle.launcher.daemon.server.exec.WatchForDisconnection.execute(WatchForDisconnection.java:37)at org.gradle.launcher.daemon.server.api.DaemonCommandExecution.proceed(DaemonCommandExecution.java:120)at org.gradle.launcher.daemon.server.exec.ResetDeprecationLogger.execute(ResetDeprecationLogger.java:26)at org.gradle.launcher.daemon.server.api.DaemonCommandExecution.proceed(DaemonCommandExecution.java:120)at org.gradle.launcher.daemon.server.exec.RequestStopIfSingleUsedDaemon.execute(RequestStopIfSingleUsedDaemon.java:34)at org.gradle.launcher.daemon.server.api.DaemonCommandExecution.proceed(DaemonCommandExecution.java:120)at org.gradle.launcher.daemon.server.exec.ForwardClientInput$2.call(ForwardClientInput.java:74)at org.gradle.launcher.daemon.server.exec.ForwardClientInput$2.call(ForwardClientInput.java:72)at org.gradle.util.Swapper.swap(Swapper.java:38)at org.gradle.launcher.daemon.server.exec.ForwardClientInput.execute(ForwardClientInput.java:72)at org.gradle.launcher.daemon.server.api.DaemonCommandExecution.proceed(DaemonCommandExecution.java:120)at org.gradle.launcher.daemon.server.health.DaemonHealthTracker.execute(DaemonHealthTracker.java:47)at org.gradle.launcher.daemon.server.api.DaemonCommandExecution.proceed(DaemonCommandExecution.java:120)at org.gradle.launcher.daemon.server.exec.LogToClient.doBuild(LogToClient.java:66)at org.gradle.launcher.daemon.server.exec.BuildCommandOnly.execute(BuildCommandOnly.java:36)at org.gradle.launcher.daemon.server.api.DaemonCommandExecution.proceed(DaemonCommandExecution.java:120)at org.gradle.launcher.daemon.server.exec.EstablishBuildEnvironment.doBuild(EstablishBuildEnvironment.java:71)at org.gradle.launcher.daemon.server.exec.BuildCommandOnly.execute(BuildCommandOnly.java:36)at org.gradle.launcher.daemon.server.api.DaemonCommandExecution.proceed(DaemonCommandExecution.java:120)at org.gradle.launcher.daemon.server.health.HintGCAfterBuild.execute(HintGCAfterBuild.java:41)at org.gradle.launcher.daemon.server.api.DaemonCommandExecution.proceed(DaemonCommandExecution.java:120)at org.gradle.launcher.daemon.server.exec.StartBuildOrRespondWithBusy$1.run(StartBuildOrRespondWithBusy.java:50)at org.gradle.launcher.daemon.server.DaemonStateCoordinator$1.run(DaemonStateCoordinator.java:246)at org.gradle.internal.concurrent.ExecutorPolicy$CatchAndRecordFailures.onExecute(ExecutorPolicy.java:54)at org.gradle.internal.concurrent.StoppableExecutorImpl$1.run(StoppableExecutorImpl.java:40)Caused by: javassist.CannotCompileException: by javassist.bytecode.BadBytecode: <clinit> ()V in com.tencent.connect.auth.AuthDialog: failed to resolve typesat javassist.CtBehavior.insertAfter(CtBehavior.java:880)at javassist.CtBehavior.insertAfter(CtBehavior.java:792)at javassist.CtBehavior$insertAfter.call(Unknown Source)at cn.jiajixin.nuwa.util.NuwaProcessor.referHackByJavassistWhenInit(NuwaProcessor.groovy:79)at cn.jiajixin.nuwa.util.NuwaProcessor.processJar(NuwaProcessor.groovy:38)at cn.jiajixin.nuwa.util.NuwaProcessor$processJar.call(Unknown Source)at cn.jiajixin.nuwa.NuwaPlugin$_apply_closure1_closure2_closure10_closure13.doCall(NuwaPlugin.groovy:221)at cn.jiajixin.nuwa.NuwaPlugin$_apply_closure1_closure2_closure10.doCall(NuwaPlugin.groovy:215)at org.gradle.api.internal.AbstractTask$ClosureTaskAction.execute(AbstractTask.java:558)at org.gradle.api.internal.AbstractTask$ClosureTaskAction.execute(AbstractTask.java:539)at org.gradle.api.internal.tasks.TaskMutator$1.execute(TaskMutator.java:77)at org.gradle.api.internal.tasks.TaskMutator$1.execute(TaskMutator.java:73)at org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter.executeAction(ExecuteActionsTaskExecuter.java:80)at org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter.executeActions(ExecuteActionsTaskExecuter.java:61)... 57 moreCaused by: javassist.bytecode.BadBytecode: <clinit> ()V in com.tencent.connect.auth.AuthDialog: failed to resolve typesat javassist.bytecode.stackmap.MapMaker.make(MapMaker.java:111)at javassist.bytecode.MethodInfo.rebuildStackMap(MethodInfo.java:456)at javassist.bytecode.MethodInfo.rebuildStackMapIf6(MethodInfo.java:438)at javassist.CtBehavior.insertAfter(CtBehavior.java:871)... 70 moreCaused by: javassist.bytecode.BadBytecode: failed to resolve typesat javassist.bytecode.stackmap.MapMaker.make(MapMaker.java:169)at javassist.bytecode.stackmap.MapMaker.make(MapMaker.java:108)... 73 moreCaused by: javassist.NotFoundException: android.content.Contextat javassist.ClassPool.get(ClassPool.java:452)at javassist.bytecode.stackmap.TypeData$TypeVar.fixTypes2(TypeData.java:418)at javassist.bytecode.stackmap.TypeData$TypeVar.fixTypes(TypeData.java:391)at javassist.bytecode.stackmap.TypeData$TypeVar.dfs(TypeData.java:338)at javassist.bytecode.stackmap.MapMaker.fixTypes(MapMaker.java:390)at javassist.bytecode.stackmap.MapMaker.make(MapMaker.java:167)... 74 more


最后一行报的问题是

Caused by: javassist.NotFoundException: android.content.Context
因此在注入类时,需要把这个类添加到路径中即可解决

<pre name="code" class="html">        //避免某些系统类找不着报错,特定添加系统的类的路径        javassist.ClassPool classPool = javassist.ClassPool.getDefault();        CtClass systemClass = classPool.makeClass("android.content.Context")        byte[] systemBytes = systemClass.toBytecode()        systemClass.defrost()        classPool.insertClassPath(new ByteArrayClassPath("android.content.Context", systemBytes))





0 0
原创粉丝点击