运行我的应用程序的模糊版本会引发以下堆栈跟踪
java.lang.RuntimeException: Unable to create service com.mycompany.myapp.async.alarms.AlarmIntentService: java.lang.IllegalStateException: Errors creating object graph: dagger.Lazy could not be bound with key dagger.Lazy required by dagger.Lazy com.mycompany.scheduler.c.mNotificationDisplayer
如果我添加-dontobfuscate,它会顺利运行
这是包含该字段的类
public abstract class AbstractAlarmSchedulerService extends IntentService { @Inject LazymNotificationDisplayer;
我在我的应用程序中从这个类扩展,但它属于一个外部库.
这些是我的匕首计划规则,复制自/sf/ask/17360801/
#Dagger -keepattributes *Annotation* -keepclassmembers,allowobfuscation class * { @javax.inject.* *; @dagger.* *;(); } -keep class * extends dagger.internal.Binding -keep class * extends dagger.internal.ModuleAdapter -keep class **$$ModuleAdapter -keep class **$$InjectAdapter -keep class **$$StaticInjection -keep class dagger.* { *; } -keep class javax.inject.* { *; } -keep class * extends dagger.internal.Binding -keep class * extends dagger.internal.ModuleAdapter -keep class * extends dagger.internal.StaticInjection -keep !abstract class com.mycompany.** { *; } -keepnames class dagger.Lazy
我已经尝试让所有类和所有成员看看是否修复了什么,但错误仍然存在
-keep class * { *; }
com.mycompany.scheduler是一个外部库,而com.mycompany.myapp包含实际应用程序的源.
如果需要,这是我正在使用的模块
@Module(injects = {AlarmIntentService.class, ReminderNotificationDisplayer.class, AlarmsBroadcastReceiver.class}) public class AndroidModule { private final AbstractMyApplication application; public AndroidModule(AbstractMyApplication application) { this.application = application; } /** * Allow the application context to be injected */ @Provides @Singleton Context provideApplicationContext() { return application; } @Provides public AlarmManager provideAlarmManager(Context context){ return (AlarmManager) context.getSystemService(Context.ALARM_SERVICE); } @Provides @Singleton public NotificationManager provideNotificationManager(Context context){ return (NotificationManager) context.getSystemService(Context.NOTIFICATION_SERVICE); } @Provides @Singleton public AbstractAlarmSchedulerNotificationDisplayer provideNotificationDisplayer() { return new ReminderNotificationDisplayer(); } }
我正在使用dagger&dagger-compiler 1.2.+依赖项
谢谢!
Dagger 1.x存在混淆问题.它可以使用适当的-keep语句进行代码收缩,但由于使用了String键,混淆变得有问题.字符串是在编程之前生成的,但是在编程之后消耗,并且不与新重命名的类型对齐.
在我们禁用反射模块适配器之前Dagger 1.x(大约1.0.0)将起作用,因为纯反射导致类型的提供和注入被认为是"及时"(即在编程之后),因此混淆类型匹配.如果代码混淆的优先级高于性能,请考虑使用这个稍微旧的版本.
Dagger 2.x(正在进行中)没有字符串键,导致直接引用类,并且应该与Proguard很好地配合.请继续关注匕首列表和项目.我们预计2.x的早期版本会在发布后几周内下降.
此外,更具体地说,请确保您-keepattributes Signature
.您看到的具体错误是因为JDK5 +泛型被proguard剥离.一个注射Lazy
,一个注射,一个注射Lazy<Foo>
.这将修复此特定错误,但您将遇到上述问题.