12

ローカルの Windows 7 マシンに FileZilla FTP サーバーをインストールしました。同じマシンに FileZilla FTP クライアントもインストールしました。サーバーとクライアントのパートナーシップが存在することを確認して、両者の間で接続が成功します。

私は FileZilla FTP サーバーに接続するための簡単で汚い Jsch プログラムを作成しました。以下はそのプログラムです。

public class TestJSch {

/** Creates a new instance of TestCommonsNet */
public TestJSch() {
}

/**
 * main - Unit test program
 * 
 * @param args
 *            Command line arguments
 * 
 */
public static void main(String[] args) {
    try {
        String ftpHost = "127.0.0.1";
        int ftpPort = 21;// 14147;
        // int ftpPort = 990;// 14147;
        String ftpUserName = "kedar";
        String ftpPassword = "XXXXXXXXXXX";
        String ftpRemoteDirectory = "C:\\KEDAR\\Java\\FTP_Folder";
        String fileToTransmit = "C:\\KEDAR\\Java\\File_Folder\\Customer.txt";
        String identityfile = "C:\\KEDAR\\Java\\Ftp\\certificate.crt";

        //
        // First Create a JSch session
        //
        JSch.setLogger(new MyLogger());
        System.out.println("Creating session.");

        JSch jsch = new JSch();

        String knownHostsFilename = "C:\\Windows\\System32\\drivers\\etc\\hosts";
        jsch.setKnownHosts(knownHostsFilename);
        jsch.addIdentity(identityfile);
        Session session = null;
        Channel channel = null;
        ChannelSftp c = null;

        //
        // Now connect and SFTP to the SFTP Server
        //
        try {
            // Create a session sending through our username and password
            session = jsch.getSession(ftpUserName, ftpHost, ftpPort);
            System.out.println("Session created.");
            session.setPassword(ftpPassword);
            // Security.addProvider(new com.sun.crypto.provider.SunJCE());

            // b
            // Setup Strict HostKeyChecking to no so we dont get the
            // unknown host key exception
            //
            java.util.Properties config = new java.util.Properties();
            config.put("StrictHostKeyChecking", "no");
            session.setConfig(config);
            session.connect();
            System.out.println("Session connected.");

            //
            // Open the SFTP channel
            //
            System.out.println("Opening Channel.");
            channel = session.openChannel("sftp");
            channel.connect();
            c = (ChannelSftp) channel;
        } catch (Exception e) {
            System.err.println("Unable to connect to FTP server."
                    + e.toString());
            throw e;
        }

        //
        // Change to the remote directory
        //
        System.out.println("Changing to FTP remote dir: "
                + ftpRemoteDirectory);
        c.cd(ftpRemoteDirectory);

        //
        // Send the file we generated
        //
        try {
            File f = new File(fileToTransmit);
            System.out.println("Storing file as remote filename: "
                    + f.getName());
            c.put(new FileInputStream(f), f.getName());
        } catch (Exception e) {
            System.err
                    .println("Storing remote file failed." + e.toString());
            throw e;
        }   

        //
        // Disconnect from the FTP server
        //
        try {
            c.quit();
        } catch (Exception exc) {
            System.err.println("Unable to disconnect from FTPserver. "
                    + exc.toString());
        }

    } catch (Exception e) {
        System.err.println("Error: " + e.toString());
    }

    System.out.println("Process Complete.");
    System.exit(0);
}

public static class MyLogger implements com.jcraft.jsch.Logger {
    static java.util.Hashtable name = new java.util.Hashtable();
    static {
        name.put(new Integer(DEBUG), "DEBUG: ");
        name.put(new Integer(INFO), "INFO: ");
        name.put(new Integer(WARN), "WARN: ");
        name.put(new Integer(ERROR), "ERROR: ");
        name.put(new Integer(FATAL), "FATAL: ");
    }

    public boolean isEnabled(int level) {
        return true;
    }

    public void log(int level, String message) {
        System.err.print(name.get(new Integer(level)));
        System.err.println(message);
    }
}
}

このプログラムを実行してみました。以下は FTP ログです。

(000033)9/12/2011 13:08:53 PM - (ログインしていません) (127.0.0.1)> 接続され、ウェルカム メッセージを送信しています...
(000033)9/12/2011 13:08:53 PM - (ログインしていない) (127.0.0.1)> 220-FileZilla Server バージョン 0.9.39 ベータ版
(000033) 2011 年 9 月 12 日 13:08:53 PM - (ログインしていない) (127.0.0.1)> 220-Tim によって書かれたKosse (Tim.Kosse@gmx.de)
(000033) 2011 年 9 月 12 日 13:08:53 PM - (ログインしていません) (127.0.0.1)> 220 http://sourceforge.net/projects/filezillaにアクセスしてください/
(000033)9/12/2011 13:08:53 PM - (ログインしていない) (127.0.0.1)> SSH-2.0-JSCH-0.1.44
(000033)9/12/2011 13:08:53 PM - (ログインしていません) (127.0.0.1)> 500 構文エラー、コマンドを認識できません。
(000033)9/12/2011 13:09:54 PM - (ログインしていない) (127.0.0.1)> 421 ログイン時間が超過しました。制御接続を閉じています。
(000033)9/12/2011 13:09:54 PM - (ログインしていません) (127.0.0.1)> 切断されました。

SSH-2.0-JSCH-0.1.44JSch プログラムがコマンドを発行し、通信が拒否される理由がわかりません。どうすればこれを回避できますか?

4

2 に答える 2

24

JSch は FTP クライアントではありません。JSch は SSH クライアントです (SFTP 実装が含まれています)。

SSH プロトコルは、シェル アクセス、ファイル転送、またはポート転送のために、サーバーへの安全な接続を可能にするプロトコルです。このためには、サーバーにSSH サーバーが必要です (通常はポート 22 ですが、異なる場合があります)。SFTP はバイナリ ファイル転送プロトコルで、通常は SSH 経由でトンネリングされ、FTP とは (名前以外では) 関係ありません。

JSch を使用してファイルをダウンロード/アップロードする場合は、コンピューターに SSH/SFTP サーバーをインストールしてアクティブにする必要があります (アクセスするコンピューターに応じて)。

FTP の場合は、他の Java ライブラリを使用する必要があります (こちらの質問から、Apache Commons FTPClient が有名なようです)。

ちなみに、JSch の既知のホストファイルは、SSH ホストの公開鍵をリストしたファイルであり、IP アドレスをリストしたファイル (ここで提供しようとしている Windows 構成ファイル) ではありません。

于 2011-09-12T23:24:18.493 に答える
3

Apache commons-net FTP ライブラリを使用します。

import java.io.IOException;

import org.apache.commons.net.ftp.FTPClient;

import org.apache.commons.net.ftp.FTPReply;

public class FTPConnectionCode {

    public static void main(String[] args) {
        String server = "www.website.com";
       // generally ftp port is 21
        int port = 21;
        String user = "ftpusername";
        String pass = "ftppassword";

        FTPClient ftpClient = new FTPClient();

        try {

            ftpClient.connect(server, port);
            showServerReply(ftpClient);

            int replyCode = ftpClient.getReplyCode();
            if (!FTPReply.isPositiveCompletion(replyCode)) {
                System.out.println("Connect failed");
                return;
            }

            boolean success = ftpClient.login(user, pass);
            showServerReply(ftpClient);

            if (!success) {
                System.out.println("Could not login to the server");
                return;
            }

            // Changes working directory
            success = ftpClient.changeWorkingDirectory("/dir");
            showServerReply(ftpClient);

            if (success) {
                System.out.println("Successfully changed working directory.");
            } else {
                System.out.println("Failed to change working directory. See server's reply.");
            }

            // logs out
            ftpClient.logout();
            ftpClient.disconnect();

        } catch (IOException ex) {
            System.out.println("Oops! Something wrong happened");
            ex.printStackTrace();
        }
    }

    private static void showServerReply(FTPClient ftpClient) {
        String[] replies = ftpClient.getReplyStrings();
        if (replies != null && replies.length > 0) {
            for (String aReply : replies) {
                System.out.println("SERVER: " + aReply);
            }
        }
    }
}
于 2017-06-14T07:58:01.367 に答える