Отправить файл изображения на веб-сервер - PullRequest
0 голосов
/ 08 марта 2012

Я пытаюсь отправить файл изображения на веб-сервер и следую существующему руководству, но при выполнении этого метода у меня возникает ошибка. Я называю путь изображения из базы данных, поэтому все изображения с локальным именем, так же как и база данных, могут быть загружены. Мой метод таков:

private void doFileUpload(){
 HttpURLConnection conn = null;
 DataOutputStream dos = null;
 DataInputStream inStream = null;
 Cursor c = helper.getUpImage(almagId);
 c.moveToFirst();
 String existingFileName = helper.getGam1(c);
 String lineEnd = "\r\n";
 String twoHyphens = "--";
 String boundary =  "*****";
 int bytesRead, bytesAvailable, bufferSize;
 byte[] buffer;
 int maxBufferSize = 1*1024*1024;
 String responseFromServer = "";
 String urlString = "http://10.234.165.232/uploader.php";
 try
 {
  //------------------ CLIENT REQUEST

 FileInputStream fileInputStream = new FileInputStream(new File(existingFileName) );
  // open a URL connection to the Servlet
  URL url = new URL(urlString);
  // Open a HTTP connection to the URL
  conn = (HttpURLConnection) url.openConnection();
  // Allow Inputs
  conn.setDoInput(true);
  // Allow Outputs
  conn.setDoOutput(true);
  // Don't use a cached copy.
  conn.setUseCaches(false);
  // Use a post method.
  conn.setRequestMethod("POST");
  conn.setRequestProperty("Connection", "Keep-Alive");
  conn.setRequestProperty("Content-Type", "multipart/form-data;boundary="+boundary);
  dos = new DataOutputStream( conn.getOutputStream() );
  dos.writeBytes(twoHyphens + boundary + lineEnd);
  dos.writeBytes("Content-Disposition: form-data; name=\"uploadedfile\";filename=\"" + existingFileName + "\"" + lineEnd);
  dos.writeBytes(lineEnd);
  // create a buffer of maximum size
  bytesAvailable = fileInputStream.available();
  bufferSize = Math.min(bytesAvailable, maxBufferSize);
  buffer = new byte[bufferSize];
  // read file and write it into form...
  bytesRead = fileInputStream.read(buffer, 0, bufferSize);
  while (bytesRead > 0)
  {
   dos.write(buffer, 0, bufferSize);
   bytesAvailable = fileInputStream.available();
   bufferSize = Math.min(bytesAvailable, maxBufferSize);
   bytesRead = fileInputStream.read(buffer, 0, bufferSize);
  }
  // send multipart form data necesssary after file data...
  dos.writeBytes(lineEnd);
  dos.writeBytes(twoHyphens + boundary + twoHyphens + lineEnd);
  // close streams
  Log.e("Debug","File is written");
  fileInputStream.close();
  dos.flush();
  dos.close();
 }
 catch (MalformedURLException ex)
 {
      Log.e("Debug", "error: " + ex.getMessage(), ex);
 }
 catch (IOException ioe)
 {
      Log.e("Debug", "error: " + ioe.getMessage(), ioe);
 }
 //------------------ read the SERVER RESPONSE
 try {
       inStream = new DataInputStream ( conn.getInputStream() );
       String str;

       while (( str = inStream.readLine()) != null)
       {
            Log.e("Debug","Server Response "+str);
       }
       inStream.close();

 }
 catch (IOException ioex){
      Log.e("Debug", "error: " + ioex.getMessage(), ioex);
 }
}

А это моя ошибка

03-08 13:49:46.174: ERROR/AndroidRuntime(1277): FATAL EXCEPTION: main
03-08 13:49:46.174: ERROR/AndroidRuntime(1277): java.lang.NullPointerException
03-08 13:49:46.174: ERROR/AndroidRuntime(1277): at com.sat.alfaloc.MenuUtama.doFileUpload(MenuUtama.java:232)
03-08 13:49:46.174: ERROR/AndroidRuntime(1277): at com.sat.alfaloc.MenuUtama.onOptionsItemSelected(MenuUtama.java:113)
03-08 13:49:46.174: ERROR/AndroidRuntime(1277): at android.app.Activity.onMenuItemSelected(Activity.java:2195)
03-08 13:49:46.174: ERROR/AndroidRuntime(1277): at com.android.internal.policy.impl.PhoneWindow.onMenuItemSelected(PhoneWindow.java:730)
03-08 13:49:46.174: ERROR/AndroidRuntime(1277): at com.android.internal.view.menu.MenuItemImpl.invoke(MenuItemImpl.java:143)
03-08 13:49:46.174: ERROR/AndroidRuntime(1277): at com.android.internal.view.menu.MenuBuilder.performItemAction(MenuBuilder.java:855)
03-08 13:49:46.174: ERROR/AndroidRuntime(1277): at com.android.internal.view.menu.IconMenuView.invokeItem(IconMenuView.java:532)
03-08 13:49:46.174: ERROR/AndroidRuntime(1277): at com.android.internal.view.menu.IconMenuItemView.performClick(IconMenuItemView.java:122)
03-08 13:49:46.174: ERROR/AndroidRuntime(1277): at android.view.View$PerformClick.run(View.java:8816)
03-08 13:49:46.174: ERROR/AndroidRuntime(1277): at android.os.Handler.handleCallback(Handler.java:587)
03-08 13:49:46.174: ERROR/AndroidRuntime(1277): at android.os.Handler.dispatchMessage(Handler.java:92)
03-08 13:49:46.174: ERROR/AndroidRuntime(1277): at android.os.Looper.loop(Looper.java:123)
03-08 13:49:46.174: ERROR/AndroidRuntime(1277): at android.app.ActivityThread.main(ActivityThread.java:4627)
03-08 13:49:46.174: ERROR/AndroidRuntime(1277): at java.lang.reflect.Method.invokeNative(Native Method)
03-08 13:49:46.174: ERROR/AndroidRuntime(1277): at java.lang.reflect.Method.invoke(Method.java:521)
03-08 13:49:46.174: ERROR/AndroidRuntime(1277): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
03-08 13:49:46.174: ERROR/AndroidRuntime(1277): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
03-08 13:49:46.174: ERROR/AndroidRuntime(1277): at dalvik.system.NativeStart.main(Native Method)

Я не знаю, что происходит с моим кодом. Думаю, это правильно. Никто не может мне помочь ??

1 Ответ

0 голосов
/ 19 сентября 2013

Я думаю, что когда вы пытаетесь создать объект conn, ваш код перетекает в одно из предложений catch первого блока try-catch. Затем впоследствии вы вызываете getInputStream () для объекта conn, который является нулевым. Я подозреваю, что возникла исключительная ситуация IOException при попытке подключения к сценарию на

http://10.234.165.232/uploader.php. 

Два вопроса, чтобы задать себе: 10.234.165.232 может пинговать? 10.234.165.232 имеет веб-сервер, прослушивающий порт 80?

Только мои два цента. Надеюсь, вы скоро решите свою проблему! :)

...