出于某种原因,升级到Lollipop(5.0.2)后,jsch停止工作。我收到这个错误。
Caused by: java.lang.ClassNotFoundException: Didn't find class
"Lorg.ietf.jgss.Oid" on path: DexPathList[[zip file"/data/app
/com.**-1/base.apk"],nativeLibraryDirectories= [/vendor/lib,
/system/lib]]
at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:56)
at java.lang.ClassLoader.loadClass(ClassLoader.java:511)
at java.lang.ClassLoader.loadClass(ClassLoader.java:469)
... 14 more
Suppressed: java.lang.ClassNotFoundException: org.ietf.jgss.Oid
at java.lang.Class.classForName(Native Method)
at java.lang.BootClassLoader.findClass(ClassLoader.java:781)
at java.lang.BootClassLoader.loadClass(ClassLoader.java:841)
at java.lang.ClassLoader.loadClass(ClassLoader.java:504)
... 15 more
Caused by: java.lang.NoClassDefFoundError: Class not found using the
boot class loader; no stack available
这是我的代码。
try {
JSch jsch = new JSch();
session = jsch.getSession(userName, remoteHost, port);
session.setPassword(userPassword);
Properties prop = new Properties();
prop.put("StrictHostKeyChecking", "no");
session.setConfig(prop);
session.connect();
channel = session.openChannel("sftp");
channel.connect();
channelSftp = (ChannelSftp)channel;
} catch (Exception ex) {
ex.printStackTrace();
session.disconnect();
}
我检测到添加了该属性" StrictHostKeyChecking "时出现问题,只有在执行" session.connect()时程序关闭&#34 ;.
如果省略此属性,程序不会失败,但无法连接。
任何想法?
感谢。
答案 0 :(得分:0)
我遇到了同样的问题。问题是由找不到与GSS-API一起使用的Lorg.ietf.jgss.Oid引起的。我发现可以通过优先使用密码验证来避免这种情况:
try {
JSch jsch = new JSch();
session = jsch.getSession(userName, remoteHost, port);
session.setPassword(userPassword);
Properties prop = new Properties();
prop.put("StrictHostKeyChecking", "no");
session.setConfig(prop);
session.setConfig("PreferredAuthentications",
"password"); //add this line to your code
session.connect();
channel = session.openChannel("sftp");
channel.connect();
channelSftp = (ChannelSftp)channel;
} catch (Exception ex) {
ex.printStackTrace();
session.disconnect();
}