【问题标题】:Server response OK (200) but no file uploaded to server服务器响应正常 (200) 但没有文件上传到服务器
【发布时间】:2014-06-20 07:59:16
【问题描述】:

我正在尝试将应用程序中生成的文本文件上传到服务器。 在尝试获取服务器响应时,我得到一个异常 EOF。

任何意见表示赞赏

我的创建文件代码:

File sdCard = android.os.Environment.getExternalStorageDirectory();
            File theDirectory = new File(sdCard.getAbsolutePath());
            theFile = new File(theDirectory, "userdetails.txt");
            theDirectory.getParentFile().mkdirs();

            //file.createNewFile();
            FileOutputStream fOut = new FileOutputStream(theFile);
            OutputStreamWriter out = new OutputStreamWriter(fOut);
            out.append(username+"\n");
            out.append(email+"\n");
            out.append(password+"\n");
            out.close();

... 上传文件名 = theFile.toString(); uploadFile(uploadFileName);

上传方式:

String fileName = sourceFileUri;

          HttpURLConnection conn = null;
          DataOutputStream dos = null;  
          String lineEnd = "\r\n";
          String twoHyphens = "--";
          String boundary = "*****";
          int bytesRead, bytesAvailable, bufferSize;
          byte[] buffer;
          int maxBufferSize = 1 * 1024 * 1024; 
          File sourceFile = new File(sourceFileUri); 

          if (!sourceFile.isFile()) {

               dialog.dismiss(); 

               Log.e("uploadFile", "Source File not exist :" + uploadFileName);

               runOnUiThread(new Runnable() {
                   public void run() {
                       Log.d("REGISTRATION PAGE", "Source File not exist :" + uploadFileName);
                   }
               }); 

               return 0;

          }
          else
          {
               try { 

                     // open a URL connection to the Servlet
                   FileInputStream fileInputStream = new FileInputStream(sourceFile);
                   URL url = new URL(upLoadServerUri);

                   // Open a HTTP  connection to  the URL
                   conn = (HttpURLConnection) url.openConnection(); 
                   conn.setDoInput(true); // Allow Inputs
                   conn.setDoOutput(true); // Allow Outputs
                   conn.setUseCaches(false); // Don't use a Cached Copy
                   conn.setRequestMethod("POST");
                   conn.setRequestProperty("Connection", "close");
                   conn.setRequestProperty("ENCTYPE", "multipart/form-data");
                   conn.setRequestProperty("Content-Type", "multipart/form-data;boundary=" + boundary);
                   conn.setRequestProperty("uploaded_file", fileName); 

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

                   dos.writeBytes(twoHyphens + boundary + lineEnd); 
                   dos.writeBytes("Content-Disposition: form-data; name=\"uploaded_file\";filename="
                                             + fileName + "" + 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);

                   // Responses from the server (code and message)
                   serverResponseCode = conn.getResponseCode();
                   String serverResponseMessage = conn.getResponseMessage();

                   Log.d("uploadFile", "HTTP Response is : "
                           + serverResponseMessage + ": " + serverResponseCode);

                   if(serverResponseCode == 200){

                       runOnUiThread(new Runnable() {
                            public void run() {

                                String msg = "File Upload Completed.\n\n See uploaded file here : \n\n"
                                              +" http://www.androidexample.com/media/uploads/"
                                              +uploadFileName;

                                //messageText.setText(msg);
                                Toast.makeText(RegisterActivity.this, "File Upload Complete.",  Toast.LENGTH_SHORT).show();
                            }
                        });                
                   }    

                   //close the streams //
                   fileInputStream.close();
                   dos.flush();
                   dos.close();

              } catch (MalformedURLException ex) {

                  dialog.dismiss();  
                  ex.printStackTrace();

                  runOnUiThread(new Runnable() {
                      public void run() {
                         // messageText.setText("MalformedURLException Exception : check script url.");
                          Toast.makeText(RegisterActivity.this, "MalformedURLException", 
                                                              Toast.LENGTH_SHORT).show();
                      }
                  });

                  Log.e("Upload file to server", "error: " + ex.getMessage(), ex);  
              } catch (Exception e) {

                  dialog.dismiss();  
                  e.printStackTrace();

                  runOnUiThread(new Runnable() {
                      public void run() {
                         // messageText.setText("Got Exception : see logcat ");
                          Toast.makeText(RegisterActivity.this, "Got Exception : see logcat ", 
                                  Toast.LENGTH_SHORT).show();
                      }
                  });
                  Log.e("Upload file to server Exception", "Exception : "
                                                   + e.getMessage(), e);  
              }
              dialog.dismiss();       
              return serverResponseCode; 

还有我在服务器上的 php 脚本:

<?php

    $file_path = "uploads/";

    $file_path = $file_path . basename( $_FILES['uploaded_file']['name']);
    if(move_uploaded_file($_FILES['uploaded_file']['tmp_name'], $file_path)) {
        echo "success";
    } else{
        echo "fail";
    }
 ?>

更新: 在这里更改了 DataOutPutStrem 参数(我在世界上有一个 \):

 dos.writeBytes("Content-Disposition: form-data; name=\"uploaded_file\";filename=\"" + fileName + "\"" + lineEnd);

这给了一个服务器

response = OK and respoonseCode = 200;

但是我在服务器目录中没有看到新文件! 我已将新文件所在的目录记录为 URL+filePath,即

www.mooneycallans/Rotunda//storage/emulated/0/userdetails.txt

但不应该这样读:

www.mooneycallans/Rotunda/userdetails.txt

... 因为 userdetails.txt 是我在应用程序中创建的文件的名称。

【问题讨论】:

  • Witch catch 报告 eof 异常?请使用Logcat。文件是否正确上传?
  • 在第一个尝试获取服务器响应的尝试块中获取 EOF 异常: // 来自服务器的响应(代码和消息) serverResponseCode = conn.getResponseCode();
  • 我检查了文件大小 (int length-theFile.lenght())=287 所以我相信文件不是空的
  • 服务器响应是'Internal Server Error: 500'
  • 您设备上的文件不是空的。但是它在服务器上的大小是多少?您有更多方法可以检查设备和服务器上的内容是否相同。

标签: php android file-upload


【解决方案1】:

哎哟。我的 php 脚本是罪魁祸首,我的路径为:

$file_path = "uploads";

代替:

$file_path = "uploads/";

一天半之后,但它起作用了:)

【讨论】:

    猜你喜欢
    • 2022-01-22
    • 2013-04-26
    • 1970-01-01
    • 2014-02-20
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2021-07-30
    相关资源
    最近更新 更多