2

次のように、ftp経由でファイルを送信するJavaコードを書いています。私が使用したサーバーは、localhost の FileZilla Server ソフトウェアです。

    public static void main(String[] args) {
    try {
        String host = "fe80::21a:a0ff:fe8d:fe63"; //No problem if ipv4
        int port = 1998;
        String username = "joe";
        String password = "123";
        String directory = "D:/ftp_share";
        File fileToTransfer = new File("D:/RND/samplefile.txt");
        String fileName = fileToTransfer.getName();
        FTPClient ftp = new FTPClient();
        ftp.connect(host, port);
        ftp.login(username, password);
        FileInputStream in = new FileInputStream(fileToTransfer);
        if (!(directory == null || "".equals(directory))) {
            ftp.changeWorkingDirectory(directory);
        }
        ftp.setFileType(FTP.BINARY_FILE_TYPE);
        ftp.appendFile(fileName, (InputStream) in);
        System.out.println("File " + fileName + " succesfully sent via ftp to " + host + " at port " + port);

    } catch (SocketException ex) {
        Logger.getLogger(Main.class.getName()).log(Level.SEVERE, null, ex);
    } catch (IOException ex) {
        Logger.getLogger(Main.class.getName()).log(Level.SEVERE, null, ex);
    }
}

問題は、IPv6 を使用せずに IPV4 経由でしか送信できないことです。Java例外は

org.apache.commons.net.ftp.FTPConnectionClosedException: FTP response 421 received.  Server closed connection.
    at org.apache.commons.net.ftp.FTP.__getReply(FTP.java:360)
    at org.apache.commons.net.ftp.FTP.__getReply(FTP.java:290)
    at org.apache.commons.net.ftp.FTP.sendCommand(FTP.java:474)
    at org.apache.commons.net.ftp.FTP.sendCommand(FTP.java:547)
    at org.apache.commons.net.ftp.FTPClient._openDataConnection_(FTPClient.java:680)
    at org.apache.commons.net.ftp.FTPClient.__storeFile(FTPClient.java:551)
    at org.apache.commons.net.ftp.FTPClient.appendFile(FTPClient.java:1765)
    at rnd.Main.main(Main.java:44)

ファイル zilla サーバーのメッセージは次のとおりです。

(000018)10/18/2011 14:46:39 PM - (not logged in) (fe80::21a:a0ff:fe8d:fe63)> Connected, sending welcome message...
(000018)10/18/2011 14:46:39 PM - (not logged in) (fe80::21a:a0ff:fe8d:fe63)> 220-FileZilla Server version 0.9.39 beta
(000018)10/18/2011 14:46:39 PM - (not logged in) (fe80::21a:a0ff:fe8d:fe63)> 220-written by Tim Kosse (Tim.Kosse@gmx.de)
(000018)10/18/2011 14:46:39 PM - (not logged in) (fe80::21a:a0ff:fe8d:fe63)> 220 Please visit http://sourceforge.net/projects/filezilla/
(000018)10/18/2011 14:46:39 PM - (not logged in) (fe80::21a:a0ff:fe8d:fe63)> USER joe
(000018)10/18/2011 14:46:39 PM - (not logged in) (fe80::21a:a0ff:fe8d:fe63)> 331 Password required for joe
(000018)10/18/2011 14:46:39 PM - (not logged in) (fe80::21a:a0ff:fe8d:fe63)> PASS ***
(000018)10/18/2011 14:46:39 PM - joe (fe80::21a:a0ff:fe8d:fe63)> 230 Logged on
(000018)10/18/2011 14:46:39 PM - joe (fe80::21a:a0ff:fe8d:fe63)> CWD D:/RND/ftp_share
(000018)10/18/2011 14:46:39 PM - joe (fe80::21a:a0ff:fe8d:fe63)> 550 CWD failed. "/D:/RND/ftp_share": directory not found.
(000018)10/18/2011 14:46:39 PM - joe (fe80::21a:a0ff:fe8d:fe63)> TYPE I
(000018)10/18/2011 14:46:39 PM - joe (fe80::21a:a0ff:fe8d:fe63)> 200 Type set to I
(000018)10/18/2011 14:46:39 PM - joe (fe80::21a:a0ff:fe8d:fe63)> EPRT |1|0.0.0.0|2885|
(000018)10/18/2011 14:46:39 PM - joe (fe80::21a:a0ff:fe8d:fe63)> 200 Port command successful
(000018)10/18/2011 14:46:39 PM - joe (fe80::21a:a0ff:fe8d:fe63)> APPE jawapannya.txt
(000018)10/18/2011 14:46:39 PM - joe (fe80::21a:a0ff:fe8d:fe63)> 421 Can't create socket

IPV6を使用して送信できるようにする方法を教えてください。

注 : ローカルには既に IPV6 があります。

4

1 に答える 1

0

その EPRT コマンドは偽物であり、サーバーに未指定の IPv4 アドレスへの接続を要求しています。

リンクローカル アドレスよりも、ローカル ホスト アドレス ::1 またはグローバル アドレスの方がうまく機能する場合があります。

于 2011-11-24T12:23:49.147 に答える