Результаты файла Java POSTing в HTTP 422 - PullRequest
0 голосов
/ 04 января 2011

Я пытаюсь создать небольшое приложение Java для подключения к приложению под названием CampFire, и у меня возникают проблемы при попытке загрузить файлы в систему. Код Java, который я использую для загрузки файла, выглядит следующим образом:

public static String postFile(String requestUri, File f)
{
  debug("Running postFile.");
  logIn();

  debug("Sending File: " + f.getAbsolutePath() + " to " + campFireURL + requestUri);

  URL url;
  URLConnection conn;

  String linebreak = "\r\n";
  String boundary = "**********xxx**********";
  String twoHyphens = "--";


  String result = "";
  String request = twoHyphens + boundary + linebreak +
    "Content-Disposition: form-data; name=\"upload\"; filename=\"" + f.getName() + "\"" + linebreak +
    linebreak +
    "";
  debug("Request: " + request);

  try
  {
   FileInputStream in = new FileInputStream(f);

   auth.resetTries();
   Authenticator.setDefault(auth);

   // Send data
   url = new URL(campFireURL + requestUri);
   conn = url.openConnection();
   conn.setDoOutput(true);
   conn.setDoInput(true);
   conn.setUseCaches(false);

   conn.setRequestProperty("Connection", "Keep-Alive");
   conn.setRequestProperty("Content-Type", "multipart/form-data; boundary=" + boundary);

   DataOutputStream wr = new DataOutputStream(conn.getOutputStream());

   wr.writeBytes(request);

   int i;
   while((i = in.read()) != -1)
   {
    wr.write(i);
   }

   wr.writeBytes(linebreak + twoHyphens + boundary + twoHyphens + linebreak);
   wr.flush();

   wr.close();
   in.close();

   result = readFromConnection(conn);
  }
  catch (Exception e)
  {
   debug(e);
   JOptionPane.showMessageDialog(null, "Error running postData: " + e.getMessage(), "HTTP POST Error", JOptionPane.ERROR_MESSAGE);
   die();
  }

  return(result);
 }

Когда я запускаю это с реальным файлом, я получаю следующие ошибки ...

Running postFile.
Sending File: /home/myuser/Desktop/blah.png to https://blah.campfirenow.com/room/blah/uploads.xml
Request: --**********xxx**********
Content-Disposition: form-data; name="upload"; filename="blah.png"
Server returned HTTP response code: 422 for URL: blah blah
java.io.IOException: Server returned HTTP response code: 422 for URL: blah blah

Есть идеи, что я здесь делаю не так? Я довольно новичок в Java и мне интересно, может быть, я пропустил что-то очевидное?

1 Ответ

2 голосов
/ 04 января 2011

Ошибка HTTP 422 означает «Необработанный объект». После быстрого взгляда я могу заметить одну ошибку: файл PNG - это двоичный файл. Вы должны добавить Content-Transfer-Encoding: binary к заголовку детали.

Если это все еще не работает, то вы можете найти пример в разделе Загрузка файлов внизу , этот ответ полезен.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...