Java FTP库Jsch的问题

时间:2018-03-27 09:35:45

标签: java jsch apache-commons-vfs

我正在使用Java 1.7,jsch 0.1.54和commons-vfs2 2.1。

这是我正在使用的代码:

JSch.setConfig("kex", "diffie-hellman-group1-sha1,curve25519-sha256@libssh.org,ecdh-sha2-nistp256,ecdh-sha2-nistp384,ecdh-sha2-nistp521,diffie-hellman-group-exchange-sha256,diffie-hellman-group14-sha1");
    final StandardFileSystemManager manager = new StandardFileSystemManager();

    try {
final FileSystemOptions opts = new FileSystemOptions();

    FtpFileSystemConfigBuilder.getInstance().setUserDirIsRoot(opts, false);
    FtpFileSystemConfigBuilder.getInstance().setPassiveMode(opts, true);

    // SSH Key checking
    SftpFileSystemConfigBuilder.getInstance().setStrictHostKeyChecking(opts, "no");
    // Root directory set to user home
    SftpFileSystemConfigBuilder.getInstance().setUserDirIsRoot(opts, false);

    // Timeout is count by Milliseconds
    SftpFileSystemConfigBuilder.getInstance().setTimeout(opts, 10000);

        manager.init();

        for (final FileFTPHelper fileFTPHelper : filesHelper) {

            final String filename = fileFTPHelper.getFilename();
            final byte[] value = fileFTPHelper.getData();

            final String remoteDestination = fileFTPHelper.getRemoteFolder() + filename;

            String connection1 = null;
            final String userInfo = fileFTPHelper.getUsername() + ":" + fileFTPHelper.getPassword();
            URI uri = null;
            try {
                uri = new URI("sftp", userInfo, fileFTPHelper.getUrl(), fileFTPHelper.getPort(), remoteDestination, null, null);
                connection1 = uri.toString();
            } catch (final URISyntaxException e) {
                throw new ValidationError("Cannot build the URL. Contact your administrator");
            }

            // Create remote file object
            FileObject remoteFile = null;
            this.log.trace("Sending file : " + remoteDestination);

            try {
                this.log.trace(connection1);
                remoteFile = manager.resolveFile(connection1, opts);
            } catch (final Exception e) {
                this.log.error(e, "Error sfp");

            }

            OutputStream io = null;
            if (remoteFile != null) {
                remoteFile.refresh();
                this.log.trace("Connected ! : " + remoteFile);

                try {

                    io = remoteFile.getContent().getOutputStream();
                    io.write(value);
                    io.flush();
                    io.close();
                } catch (final IOException e1) {
                } finally {
                    if (io != null)
                        try {
                            io.close();
                        } catch (final Exception e) {
                            // TODO Auto-generated catch block
                            e.printStackTrace();
                        }
                }
                remoteFile.close();
                if (!remoteFile.exists())
                    throw new ValidationError("Issue when sending files over sftp : The file has not been copied on the FTP");

                if (!remoteFile.isFile())
                    throw new ValidationError("Issue when sending files over sftp : The file is not a file");
            }
            else
                throw new ValidationError("Issue when sending files over sftp : Could not resolve file on the FTP");

            System.out.println("File upload success");
        }
    } catch (final Exception e) {
        this.log.error(e, "Error");
        throw new ValidationError("Issue when sending files over sftp : " + e.getMessage());

    } finally {
        manager.close();
    }

和输出我得到:

SftpClientFactory(line 362) - Connecting to ftpqa.aaaa.com port 22
SftpClientFactory(line 362) - Connection established
SftpClientFactory(line 362) - Remote version string: SSH-2.0-Serv-U_15.1.6.26
SftpClientFactory(line 362) - Local version string: SSH-2.0-JSCH-0.1.54
SftpClientFactory(line 362) - CheckCiphers: aes256-ctr,aes192-ctr,aes128-ctr,aes256-cbc,aes192-cbc,aes128-cbc,3des-ctr,arcfour,arcfour128,arcfour256
SftpClientFactory(line 362) - aes256-ctr is not available.
SftpClientFactory(line 362) - aes192-ctr is not available.
SftpClientFactory(line 362) - aes256-cbc is not available.
SftpClientFactory(line 362) - aes192-cbc is not available.
SftpClientFactory(line 362) - CheckKexes: diffie-hellman-group14-sha1,ecdh-sha2-nistp256,ecdh-sha2-nistp384,ecdh-sha2-nistp521
SftpClientFactory(line 362) - diffie-hellman-group14-sha1 is not available.
SftpClientFactory(line 362) - CheckSignatures: ecdsa-sha2-nistp256,ecdsa-sha2-nistp384,ecdsa-sha2-nistp521
SftpClientFactory(line 362) - SSH_MSG_KEXINIT sent
SftpClientFactory(line 362) - SSH_MSG_KEXINIT received
SftpClientFactory(line 362) - kex: server: ecdh-sha2-nistp256,ecdh-sha2-nistp384,ecdh-sha2-nistp521,diffie-hellman-group14-sha1
SftpClientFactory(line 362) - kex: server: ssh-rsa
SftpClientFactory(line 362) - kex: server: aes256-cbc,rijndael256-cbc,rijndael-cbc@lysator.liu.se,aes256-ctr
SftpClientFactory(line 362) - kex: server: aes256-cbc,rijndael256-cbc,rijndael-cbc@lysator.liu.se,aes256-ctr
SftpClientFactory(line 362) - kex: server: hmac-sha2-256,hmac-sha2-256-96,hmac-sha2-512,hmac-sha2-512-96
SftpClientFactory(line 362) - kex: server: hmac-sha2-256,hmac-sha2-256-96,hmac-sha2-512,hmac-sha2-512-96
SftpClientFactory(line 362) - kex: server: zlib,none
SftpClientFactory(line 362) - kex: server: zlib,none
SftpClientFactory(line 362) - kex: server: 
SftpClientFactory(line 362) - kex: server: 
SftpClientFactory(line 362) - kex: client: ecdh-sha2-nistp256,ecdh-sha2-nistp384,ecdh-sha2-nistp521,diffie-hellman-group-exchange-sha256,diffie-hellman-group-exchange-sha1,diffie-hellman-group1-sha1
SftpClientFactory(line 362) - kex: client: ssh-rsa,ssh-dss,ecdsa-sha2-nistp256,ecdsa-sha2-nistp384,ecdsa-sha2-nistp521
SftpClientFactory(line 362) - kex: client: aes128-ctr,aes128-cbc,3des-ctr,3des-cbc,blowfish-cbc
SftpClientFactory(line 362) - kex: client: aes128-ctr,aes128-cbc,3des-ctr,3des-cbc,blowfish-cbc
SftpClientFactory(line 362) - kex: client: hmac-md5,hmac-sha1,hmac-sha2-256,hmac-sha1-96,hmac-md5-96
SftpClientFactory(line 362) - kex: client: hmac-md5,hmac-sha1,hmac-sha2-256,hmac-sha1-96,hmac-md5-96
SftpClientFactory(line 362) - kex: client: none
SftpClientFactory(line 362) - kex: client: none
SftpClientFactory(line 362) - kex: client: 
SftpClientFactory(line 362) - kex: client: 
SftpClientFactory(line 362) - Disconnecting from ftpqa.aaaa.com port 22

我得到以下例外:

  org.apache.commons.vfs2.FileSystemException - Could not connect to SFTP server at "sftp://***:***@ftpqa.aaaa.com/".
  org.apache.commons.vfs2.FileSystemException - Could not connect to SFTP server at "ftpqa.aaaa.com".
  com.jcraft.jsch.JSchException - Algorithm negotiation fail

我在各种网站上看了一下,算法协商失败似乎与丢失的算法有关。我添加了代码JSch.setConfig(" kex"," diffie-hellman-group1-sha1,curve25519-sha256 @ libssh.org,ecdh-sha2-nistp256,ecdh-sha2-nistp384,ecdh -sha2-nistp521,的Diffie-Hellman群交换-SHA256,的Diffie-Hellman-group14-SHA1&#34);但它看不到你的工作。有什么想法吗?

1 个答案:

答案 0 :(得分:1)

我修复了我的问题,但在http://www.oracle.com/technetwork/java/javase/downloads/jce-7-download-432124.html下载了Java Cryptography Extension(JCE)Unlimited Strength Jurisdiction Policy Files并将它们安装在java-home \ lib \ security