0

我目前正在运行 Java Mina SSHD 服务器。我的服务器运行良好,sshd-core-0.14.0但我的病毒扫描程序标记了弱密码,让我别无选择,只能升级到 version 2.5.1。我尝试简单地替换 .jar 文件并将classpathvars 更改为新版本,但出现以下错误。

Error: A JNI error has occurred, please check your installation and try again
Exception in thread "main" java.lang.NoClassDefFoundError: org.apache.sshd.commo
n.KeyPairProvider
        at java.lang.J9VMInternals.prepareClassImpl(Native Method)
        at java.lang.J9VMInternals.prepare(J9VMInternals.java:303)
        at java.lang.Class.getMethodHelper(Class.java:1247)
        at java.lang.Class.getMethod(Class.java:1191)
        at sun.launcher.LauncherHelper.validateMainClass(LauncherHelper.java:556
)
        at sun.launcher.LauncherHelper.checkAndLoadMain(LauncherHelper.java:538)
Caused by: java.lang.ClassNotFoundException: org.apache.sshd.common.KeyPairProvi
der
        at java.net.URLClassLoader.findClass(URLClassLoader.java:610)
        at java.lang.ClassLoader.loadClassHelper(ClassLoader.java:944)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:889)
        at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:349)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:872)
        ... 6 more

启动我的基于 java 的 SSHD 的代码在这里:

import org.apache.sshd.SshServer;
import org.apache.sshd.server.keyprovider.SimpleGeneratorHostKeyProvider;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

public class WinSSHServer {
    public WinSSHServer(Properties props) throws IOException {
        final SshServer sshd = SshServer.setUpDefaultServer();

        sshd.getProperties().put(SshServer.IDLE_TIMEOUT, String.valueOf(sessionTimeoutMSec));
        sshd.setPort(22);
        sshd.setKeyPairProvider(new SimpleGeneratorHostKeyProvider(props.getProperty("hostkey")));
        sshd.setCommandFactory(new WinCmdExeCommandFactory());

        final PuTTYPublicKeyAuthenticator pka = new PuTTYPublicKeyAuthenticator();
        addPublicKeysFromProps(pka, props);
        sshd.setPublickeyAuthenticator(pka);

        sshd.start();
    }
4

2 回答 2

0

可能版本0.14.0和2.5.1有很大的区别那个类在2.5.1中可能并不真的存在所以

  1. 尝试首先使用新版本编译您的项目(而不是更改库中的 jar)
  2. 相应地更改您的代码以符合新版本
于 2020-09-15T13:30:26.730 回答
0

我在一个 maven 存储库索引站点中搜索,发现一个包含相同类的 JAR。但是,您可能必须最终配置的路径发生了变化。

我使用一个 zip 实用程序 (7zip) 来搜索包以查找有问题的类名及其完全限定的类路径。还有其他方法可以做到这一点。

https://mvnrepository.com/artifact/org.apache.sshd/sshd-common/2.5.1

原始海报在异常堆栈中给出的路径是org.apache.sshd.common.KeyPairProvider但是在这个包中它似乎是org.apache.sshd.common.keyprovider.KeyPairProvider(注意添加的keyprovider)。

故障排除步骤:

  1. 确认你的一个罐子里有这个班级
  2. 如果KeyPairProvider的完全限定类名确实发生了如上所述的变化,则更新对新的完全限定类名的引用
于 2020-09-15T13:44:03.007 回答