java - Android 中 jcraft jsch SFTP 库的 ClassNotFound 异常

标签 java android sftp jsch

我正在尝试使用 jcraft 的 jsch 库从 Android 设备使用 SFTP 上传文件。 在应用程序的 Debug模式下,该过程绝对正常,我能够正确上传文件。但是当我在 Release模式下构建应用程序时,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'

我尝试用本地 JAR 替换 gradle 库,也尝试在 Release模式下禁用 proGuard 规则。

这可能是什么原因造成的?

如果您需要任何其他信息进行诊断,请告诉我。

最佳答案

添加到proguard-rules.pro: -保持类 com.jcraft.jsch.** { *;

关于java - Android 中 jcraft jsch SFTP 库的 ClassNotFound 异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59642339/

相关文章:

java - html View 中的 iText 等宽字体,带有 css 样式的粗体、斜体

java - Artifactory初始化失败: Context is null

android - 获取颜色资源作为字符串

java - 在 xml 中显示整数值的代码是什么?

java - 无法连续读取/监视远程文件

ftp - Google Drive 作为 FTP 服务器

java - 无法连接到 zookeeper,然后 hbase master 关闭

java - 如何模拟 REST 请求

android - 压缩图像而不损失质量

java - 导出数据和SFTP