Исключение ClassNotFound для SFTP-библиотеки jcraft jsch в android - PullRequest
2 голосов
/ 08 января 2020

Я пытаюсь загрузить файлы с использованием SFTP с устройства android с помощью библиотеки jcraft jcraft. В режиме отладки приложения процесс работает абсолютно нормально, и я могу правильно загрузить файлы. Но когда я создаю приложение в режиме выпуска, библиотека jsch выдает следующее исключение.

01-08 11:48:00.905 8083-8182/? W/System.err: b.c.a.c0: java.lang.ClassNotFoundException: com.jcraft.jsch.jce.Random
01-08 11:48:00.905 8083-8182/? W/System.err:     at b.c.a.d1.a()
01-08 11:48:00.905 8083-8182/? W/System.err:     at b.c.a.d1.a()
01-08 11:48:00.905 8083-8182/? W/System.err:     at b.d.b.i.b.a()
01-08 11:48:00.905 8083-8182/? W/System.err:     at b.d.b.i.b.doInBackground()
01-08 11:48:00.906 8083-8182/? W/System.err:     at android.os.AsyncTask$2.call(AsyncTask.java:292)
01-08 11:48:00.906 8083-8182/? W/System.err:     at java.util.concurrent.FutureTask.run(FutureTask.java:237)
01-08 11:48:00.906 8083-8182/? W/System.err:     at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:231)
01-08 11:48:00.906 8083-8182/? W/System.err:     at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)
01-08 11:48:00.906 8083-8182/? W/System.err:     at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587)
01-08 11:48:00.906 8083-8182/? W/System.err:     at java.lang.Thread.run(Thread.java:818)
01-08 11:48:00.906 8083-8182/? W/System.err: Caused by: java.lang.ClassNotFoundException: com.jcraft.jsch.jce.Random
01-08 11:48:00.907 8083-8182/? W/System.err:     at java.lang.Class.classForName(Native Method)
01-08 11:48:00.907 8083-8182/? W/System.err:     at java.lang.Class.forName(Class.java:309)
01-08 11:48:00.907 8083-8182/? W/System.err:     at java.lang.Class.forName(Class.java:273)
01-08 11:48:00.907 8083-8182/? W/System.err:    ... 10 more
01-08 11:48:00.907 8083-8182/? W/System.err: Caused by: java.lang.ClassNotFoundException: Didn't find class "com.jcraft.jsch.jce.Random" on path: DexPathList[[zip file "/data/app/com.spirituspay.spaycardapplication-1/base.apk"],nativeLibraryDirectories=[/vendor/lib, /system/lib]]
01-08 11:48:00.908 8083-8182/? W/System.err:     at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:56)
01-08 11:48:00.908 8083-8182/? W/System.err:     at java.lang.ClassLoader.loadClass(ClassLoader.java:511)
01-08 11:48:00.908 8083-8182/? W/System.err:     at java.lang.ClassLoader.loadClass(ClassLoader.java:469)
01-08 11:48:00.908 8083-8182/? W/System.err:    ... 13 more
01-08 11:48:00.908 8083-8182/? W/System.err:    Suppressed: java.lang.ClassNotFoundException: com.jcraft.jsch.jce.Random
01-08 11:48:00.908 8083-8182/? W/System.err:     at java.lang.Class.classForName(Native Method)
01-08 11:48:00.908 8083-8182/? W/System.err:     at java.lang.BootClassLoader.findClass(ClassLoader.java:781)
01-08 11:48:00.908 8083-8182/? W/System.err:     at java.lang.BootClassLoader.loadClass(ClassLoader.java:841)
01-08 11:48:00.908 8083-8182/? W/System.err:     at java.lang.ClassLoader.loadClass(ClassLoader.java:504)
01-08 11:48:00.908 8083-8182/? W/System.err:        ... 14 more
01-08 11:48:00.908 8083-8182/? W/System.err:    Caused by: java.lang.NoClassDefFoundError: Class not found using the boot class loader; no stack available'

Я пытался заменить библиотеку gradle на локальный JAR, также пытался отключить правила proGuard в режиме выпуска.

Что еще может быть причиной этого?

Пожалуйста, дайте мне знать, если вам нужна другая информация для диагностики c.

1 Ответ

0 голосов
/ 25 марта 2020

добавить в proguard-rules.pro: -keep class com.jcraft.jsch. ** {*; }

...