Не удается записать в BufferedOutputStream, который подключен к URLConnection - PullRequest
0 голосов
/ 07 января 2012

Я пытаюсь загрузить файл на FTP-сервер, используя URLConnection. Нет никаких исключений. Кажется, я могу подключиться к серверу. Я могу загрузить файл (с другой программой) без проблем, если я загружу его «вручную» (с помощью FTP-клиента).

Я использую BufferedOutputStream.write (int). Журнал показывает, что я могу прочитать локальный файл (который содержит «Hej hej») и получить доступ к байтам в нем. Проблема в том, что в файл сервера ничего не записано. Когда я читаю файл на сервере, он все еще содержит содержимое для предварительной загрузки. Файл не обновлен. Я пробовал BufferedOutputStream.write (String.getBytes ()), но это не помогло.

static public void upload(String string, String file) {
    File file_ = new File(Environment.getExternalStorageDirectory() + "/Android/data/org.sionlinkoping.pingstprayer/files/thanks.txt");
try {
    upload("ftphome.mah.se", user, passwd, "thanks.txt", file_);
}
catch(Exception e) { Log.d("",e.toString()); }
}


static public void upload( String ftpServer, String user, String password,
        String fileName, File source ) throws MalformedURLException,
    IOException
{
    if (ftpServer != null && fileName != null && source != null)
{
    StringBuffer sb = new StringBuffer( "ftp://" );
    // check for authentication else assume its anonymous access.
    if (user != null && password != null)
    {
        sb.append( user );
        sb.append( ':' );
        sb.append( password );
        sb.append( '@' );
    }
    sb.append( ftpServer );
    sb.append( '/' );
    sb.append( fileName );

        BufferedInputStream bis = null;
    BufferedOutputStream bos = null;
    try
        {
        URL url = new URL( sb.toString() );
        URLConnection urlc = url.openConnection();

            bos = new BufferedOutputStream( urlc.getOutputStream() );
        bis = new BufferedInputStream( new FileInputStream( source ) );

            int i;
        // read byte by byte until end of stream
        while ((i = bis.read()) != -1)
        {
            Log.d("","i:"+i);
            bos.write( i );
        }
        bos.flush();
    }
    finally
    {
        if (bis != null)
            try
            {
                bis.close();
            }
            catch (IOException ioe)
            {
                ioe.printStackTrace();
            }
        if (bos != null)
            try
            {
               bos.close();
            }
            catch (IOException ioe)
            {
                ioe.printStackTrace();
            }
    }
    }
else
{
    System.out.println( "Input not available." );
}
}

Журнал показывает:

01-07 14:00:50.662: DEBUG/(6925): i:239
01-07 14:00:50.662: DEBUG/(6925): i:187
01-07 14:00:50.662: DEBUG/(6925): i:191
01-07 14:00:50.662: DEBUG/(6925): i:72
01-07 14:00:50.662: DEBUG/(6925): i:101
01-07 14:00:50.662: DEBUG/(6925): i:106
01-07 14:00:50.662: DEBUG/(6925): i:32
01-07 14:00:50.662: DEBUG/(6925): i:104
01-07 14:00:50.662: DEBUG/(6925): i:101
01-07 14:00:50.662: DEBUG/(6925): i:106
01-07 14:00:50.672: DEBUG/(6925): i:10

1 Ответ

2 голосов
/ 07 января 2012

Проблема заключается в том, что вы предполагаете, что запись по URL-адресу FTP приведет к сохранению файла на сервере.Не будетРезультаты просто не определены - так не работает.

Доступны библиотеки FTP;вам нужно будет использовать один.Например, см. здесь.

...