使用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
- 使用nuwa热补丁的编译注入第三方jar类的问题
- 热修复框架nuwa的使用
- 关于热修复框架nuwa的使用
- Android热更新框架Nuwa的使用
- 关于热修复框架nuwa的使用
- 热修复框架nuwa的使用
- 编译引用第三方jar包的类
- 热补丁Nuwa配置说明
- Storm开发打包问题:Ant编译把第三方jar打入打包的JAR中
- Storm开发打包问题:Ant编译把第三方jar打入打包的JAR中
- Android引入第三方jar的问题
- Android Studio第三方jar的使用
- Android的apk编译和第三方jar包的使用
- 在android中,编译的项目使用到第三方jar的导入方法 终极版!
- 在android中,编译的项目使用到第三方jar的导入方法 终极版!
- Android Studio 怎么添加使用第三方jar包及无法编译的问题解决方法
- Android Studio 怎么添加使用第三方jar包及无法编译的问题解决方法
- Android编译带有第三方jar包的软件。
- 1100. Mars Numbers
- 【GDOI2017模拟9.24】周末晚会
- 最短路径dijkstra-与最小生树prim算法对比
- <sdut-ACM>顺序表应用4:元素位置互换之逆置算法
- 404. Sum of Left Leaves
- 使用nuwa热补丁的编译注入第三方jar类的问题
- PHP实现MVC开发: 一个简单的MVC
- 【线性规划与网络流24题 1】飞行员配对方案
- POJ-3071-Football
- 长尾狐狸(简单dp)
- Java ArrayList LinkedList
- 25补间动画
- 理解回溯法
- poj3904容斥原理