FTP-клиент продолжает получать отказ в разрешении на загрузку с сервера


Я пытаюсь написать FTP-клиент и сервер, которые позволят мне отправлять файл с клиента на сервер через анонимный FTP. Однако я продолжаю получать 550 Permission Denied. Я могу делать и другие вещи, такие как загрузка файла с сервера или получение списка файлов в Каталоге, но всякий раз, когда я пытаюсь сделать загрузку, он говорит 550 Permission Denied. Результат будет одинаковым независимо от того, войду ли я в систему или использую анонимный FTP.

Я не вижу никаких проблем с моим кодом, но я пробовал запускать его в разных сетях и компьютеры с тем же результатом. Есть ли проблема с кодом, который я не вижу, или мне нужно что-то сделать с маршрутизатором/брандмауэром?

Я пишу как клиент, так и сервер на Java и запускаю Windows. Библиотеки, которые я использую, - это Apache Commons FTP Client и Apache FTP Server.

Вот клиент. Закомментированный код предназначен для загрузки и получения списка файлов в каталоге.

import org.apache.commons.net.ftp.*;
import java.io.*;
import java.net.*;

public class Client
{
    public Client()
    {
        // Do nothing
    }

    public void transferFile(String ipAddress)
    {
        // For uploading
        FileInputStream file = null;
        // For downloading
        // FileOutputStream file = null;

        try
        {
            InetAddress address = InetAddress.getByName(ipAddress);

            FTPClient ftpClient = new FTPClient();
            ftpClient.connect(address, 5000);
            ftpClient.login("anonymous", "");
            ftpClient.setFileType(FTP.BINARY_FILE_TYPE);
            ftpClient.enterLocalPassiveMode();

            // For uploading
            file = new FileInputStream(new File("C:/SoundFiles/Send/Test1.txt"));
            // For downloading
            // file = new FileOutputStream(new File("C:/SoundFiles/Receive/Test2.txt"));

            // For uploading
            boolean success = ftpClient.storeFile("/Receive/Test2.txt", file);
            // For downloading
            // boolean success = ftpClient.retrieveFile("/Send/Test1.txt", file);

            // For listing the files on the server's directory
            /*
            FTPFile[] directoryFiles = ftpClient.listFiles();  
            System.out.println("There are " + directoryFiles.length + " files");
            for(int i = 0; i < directoryFiles.length; i++)
            {
                System.out.println(i + ": " + directoryFiles[i].getName());
            }
            */

            if(success)
                System.out.println("Success.");
            else
                System.out.println("Fail.");

            ftpClient.logout();
            ftpClient.disconnect();
        }
        catch(IOException e)
        {
            e.printStackTrace();
        }
        finally
        {
            try
            {
                if(file != null)
                    file.close();
            }
            catch(IOException e)
            {
                e.printStackTrace();
            }
        }
    }

    public static void main(String[] args)
    {
        Client client = new Client();
        client.transferFile("Enter your IP address here");
    }
}

Вот сервер.

import org.apache.ftpserver.FtpServer;
import org.apache.ftpserver.FtpServerFactory;
import org.apache.ftpserver.ConnectionConfigFactory;
import org.apache.ftpserver.usermanager.impl.BaseUser;
import org.apache.ftpserver.listener.ListenerFactory;
import org.apache.ftpserver.ftplet.FtpException;
import org.apache.ftpserver.ftplet.UserManager;

public class Server
{
    public Server()
    {
        // Do nothing
    }

    public void startServer()
    {
        FtpServer server = null;

        try
        {
            FtpServerFactory ftpServerFactory = new FtpServerFactory();

            ListenerFactory listenerFactory = new ListenerFactory();
            listenerFactory.setPort(5000);
            ftpServerFactory.addListener("default", listenerFactory.createListener());

            ConnectionConfigFactory configFactory = new ConnectionConfigFactory();
            configFactory.setAnonymousLoginEnabled(true);
            ftpServerFactory.setConnectionConfig(configFactory.createConnectionConfig());

            BaseUser user = new BaseUser();
            user.setName("anonymous");
            user.setPassword("");
            user.setHomeDirectory("C:/SoundFiles");
            UserManager userManager = ftpServerFactory.getUserManager();
            userManager.save(user);

            server = ftpServerFactory.createServer();
            server.start();
        }
        catch (FtpException e)
        {
            e.printStackTrace();
        }

        // Stop the server after 10 seconds
        try
        {
            Thread.sleep(10000);
        }
        catch(InterruptedException e)
        {
            e.printStackTrace();
        }

        if(server != null)
            server.stop();
    }

    public static void main(String[] args)
    {
        Server server = new Server();
        server.startServer();
    }
}

Это вывод, который я продолжаю получать из сервер.

[main] INFO org.apache.ftpserver.impl.DefaultFtpServer - FTP server started
[NioProcessor-3] INFO org.apache.ftpserver.listener.nio.FtpLoggingFilter - CREATED
[pool-3-thread-1] INFO org.apache.ftpserver.listener.nio.FtpLoggingFilter - OPENED
[pool-3-thread-1] INFO org.apache.ftpserver.listener.nio.FtpLoggingFilter - SENT: 220 Service ready for new user.

[pool-3-thread-1] INFO org.apache.ftpserver.listener.nio.FtpLoggingFilter - RECEIVED: USER anonymous
[pool-3-thread-1] INFO org.apache.ftpserver.listener.nio.FtpLoggingFilter - SENT: 331 Guest login okay, send your complete e-mail address as password.

[pool-3-thread-1] INFO org.apache.ftpserver.listener.nio.FtpLoggingFilter - RECEIVED: PASS 
[pool-3-thread-1] INFO org.apache.ftpserver.command.impl.PASS - Anonymous login success - null
[pool-3-thread-2] INFO org.apache.ftpserver.listener.nio.FtpLoggingFilter - SENT: 230 User logged in, proceed.

[pool-3-thread-2] INFO org.apache.ftpserver.listener.nio.FtpLoggingFilter - RECEIVED: TYPE I
[pool-3-thread-1] INFO org.apache.ftpserver.listener.nio.FtpLoggingFilter - SENT: 200 Command TYPE okay.

[pool-3-thread-2] INFO org.apache.ftpserver.listener.nio.FtpLoggingFilter - RECEIVED: PASV
[pool-3-thread-1] INFO org.apache.ftpserver.listener.nio.FtpLoggingFilter - SENT: 227 Entering Passive Mode

[pool-3-thread-2] INFO org.apache.ftpserver.listener.nio.FtpLoggingFilter - RECEIVED: STOR /Receive/Test2.txt
[pool-3-thread-2] WARN org.apache.ftpserver.impl.PassivePorts - Releasing unreserved passive port: 2133
[pool-3-thread-2] INFO org.apache.ftpserver.listener.nio.FtpLoggingFilter - SENT: 550 /Receive/Test2.txt: Permission denied.

[pool-3-thread-1] INFO org.apache.ftpserver.listener.nio.FtpLoggingFilter - RECEIVED: QUIT
[pool-3-thread-1] INFO org.apache.ftpserver.listener.nio.FtpLoggingFilter - SENT: 221 Goodbye.

[pool-3-thread-1] INFO org.apache.ftpserver.listener.nio.FtpLoggingFilter - CLOSED

Любые предложения о том, как я могу заставить это работать, очень ценятся.

1 5

1 ответ:

Я в конечном итоге выяснить, что не хватает. Мне просто нужно было добавить следующие строки кода в класс сервера.

List<Authority> authorities = new ArrayList<Authority>();
authorities.add(new WritePermission());
user.setAuthorities(authorities);