ProGuard发布的应用中的Android错误

时间:2017-09-13 09:57:07

标签: android printing android-proguard

我已经完成了一个使用EPSON Printer SDK的应用 所以,我有一些EPSON热敏打印机的库文件,我正在使用它们在我的应用程序

所以这里App正在成功运行,我正在打印数据

现在我制作了apk的发行版并签名

我的应用程序位于不同的软件包(com.mytest.mapp)中,打印机位于其他软件包(com.epson.epos2_printer)中,我正在使用库libepos2.so

当我尝试打印应用程序时崩溃了

我遵循了许多proguard表单,并在proguard-rules

中添加了这些表单
-keep class  com.epson.epos2** {
    *;
}

minifyEnabled true

时仍然面临同样的问题

如果它的错误,其发布版本的工作正常可以任何1建议我EPSON SDK库缺少什么

这是我的错误日志

   No pending exception expected: java.lang.ClassNotFoundException: Didn't find class "com.epson.epsonio.bluetooth.NetBt" on path: DexPathList[[zip file "/data/app/com.mytest.mapp-1/base.apk"],nativeLibraryDirectories=[/data/app/com.mytest.mapp-1/lib/arm, /vendor/lib, /system/lib]]
   at java.lang.Class dalvik.system.BaseDexClassLoader.findClass(java.lang.String) (BaseDexClassLoader.java:56)
   at java.lang.Class java.lang.ClassLoader.loadClass(java.lang.String, boolean) (ClassLoader.java:511)
   at java.lang.Class java.lang.ClassLoader.loadClass(java.lang.String) (ClassLoader.java:469)
   at java.lang.String java.lang.Runtime.nativeLoad(java.lang.String, java.lang.ClassLoader, java.lang.String) (Runtime.java:-2)
   at java.lang.String java.lang.Runtime.doLoad(java.lang.String, java.lang.ClassLoader) (Runtime.java:428)
   at void java.lang.Runtime.loadLibrary(java.lang.String, java.lang.ClassLoader) (Runtime.java:369)
   at void java.lang.System.loadLibrary(java.lang.String) (System.java:989)
   at void com.epson.epos2.discovery.Discovery.<clinit>() ((null):-1)
   at void com.mytest.mapp.pdata.PrintMActivity.onCreate(android.os.Bundle) ((null):-1)
   at void android.app.Activity.performCreate(android.os.Bundle) (Activity.java:6289)
   at void android.app.Instrumentation.callActivityOnCreate(android.app.Activity, android.os.Bundle) (Instrumentation.java:1119)
   at android.app.Activity android.app.ActivityThread.performLaunchActivity(android.app.ActivityThread$ActivityClientRecord, android.content.Intent) (ActivityThread.java:2655)
   at void android.app.ActivityThread.handleLaunchActivity(android.app.ActivityThread$ActivityClientRecord, android.content.Intent) (ActivityThread.java:2767)
   at void android.app.ActivityThread.access$900(android.app.ActivityThread, android.app.ActivityThread$ActivityClientRecord, android.content.Intent) (ActivityThread.java:177)
   at void android.app.ActivityThread$H.handleMessage(android.os.Message) (ActivityThread.java:1449)
   at void android.os.Handler.dispatchMessage(android.os.Message) (Handler.java:102)
   at void android.os.Looper.loop() (Looper.java:145)
   at void android.app.ActivityThread.main(java.lang.String[]) (ActivityThread.java:5951)
   at java.lang.Object java.lang.reflect.Method.invoke!(java.lang.Object, java.lang.Object[], boolean) (Method.java:-2)
   at java.lang.Object java.lang.reflect.Method.invoke(java.lang.Object, java.lang.Object[]) (Method.java:372)
   at void com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run() (ZygoteInit.java:1400)
   at void com.android.internal.os.ZygoteInit.main(java.lang.String[]) (ZygoteInit.java:1195)

2 个答案:

答案 0 :(得分:1)

我也遇到了与蓝牙打印机和爱普生打印机相同的错误。更好地使用

-ignorewarnings / -dontwarn class/package name
-keep class * {
    public private *;
}

Dot忘记保留我们的课程/包名称

希望这有效

答案 1 :(得分:0)

我知道这是一个古老的威胁,但我希望这能帮助将来遇到此主题的人。

添加如下所示的广泛的 -keep 选项是一种不好的做法,这将防止 ProGuard 缩小、优化和混淆整个项目(标记为 protected 的部分代码除外)。

-keep class * {
    public private *
}

相反,当遇到 ClassNotFoundException 时,您应该为缺失的类添加一个 -keep 选项。在 OP 的情况下,这将是 -keep class com.epson.epsonio.bluetooth.NetBt

您可以查看 ProGuard Playground 上的差异,它可以很好地显示哪些类受您的 -keep 选项影响,而无需一遍又一遍地编译。