8

私はこの問題をデバッグするために最後の日かそこらを費やしましたが、アイデアがありません。基本的に、PHP/Apache Web サーバーにデータを POST する Android アプリがあります。このコードをローカル テスト サーバーに向けると、問題なく動作するようです。また、実稼働サーバーでそれを指すと正常に動作するように見えますが、行をコメントアウトした場合にのみconn.setChunkedStreamingMode(maxBufferSize);. その行が有効になると、投稿はローカル テスト サーバーでのみ機能しますが、運用サーバーに投稿すると、PHP $_FILES 配列は空になります。多数の値 (0 と 1024 を含む) を渡そうとしましsetChunkedStreamingModeたが、どれも問題を解決していないようです。

この時点で、問題は本番サーバーの PHP の構成方法に関係していると思いますが、私が知る限り、サーバーの重要なパラメーターはすべてテスト インスタンスと同じです。さらに、どちらも同じバージョンの Apache と PHP を実行しています。私の運用サーバーは Bluehost によって実行されています。

アップロードに使用しているJavaコードは次のとおりです。

HttpURLConnection conn = null;
DataOutputStream dos = null;
DataInputStream inStream = null;
String lineEnd = "\r\n";
String twoHyphens = "--";
String boundary = "***************************************************";
int bytesRead, bytesAvailable, bufferSize;
byte[] buffer;
int maxBufferSize = 212144; // 1024*1024 = 1MB.  212144 is a quarter MB.
FileInputStream fileInputStream = null;
try
{
  // ------------------ CLIENT REQUEST
  fileInputStream = new FileInputStream(new File(existingFileWithFullPath));
  // open a URL connection to the Servlet
  URL url = new URL(BACKUP_POST_URL);
  // Open a HTTP connection to the URL
  conn = (HttpURLConnection) url.openConnection();
  // Allow Inputs
  conn.setDoInput(true);
  // Allow Outputs
  conn.setDoOutput(true);
  // Send in chunks (to avoid out of memory error)
  conn.setChunkedStreamingMode(maxBufferSize);
  // 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);
  conn.setReadTimeout(200000); // 200 seconds...
  dos = new DataOutputStream(conn.getOutputStream());
  dos.writeBytes(twoHyphens + boundary + lineEnd);
  dos.writeBytes("Content-Disposition: form-data; name=\"uploadedfile\";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)
  {
    try {
      dos.write(buffer, 0, bufferSize);          
    } catch (OutOfMemoryError oome) {
      Log.e(CommonStatic.LOG_NAME, "Out of memory error caught...");
      oome.printStackTrace();
      fileInputStream.close();
      throw new Exception("Out Of Memory!");
    }
    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);
  fileInputStream.close();
  dos.flush();
  dos.close();

  // close streams
  Log.d(CommonStatic.LOG_NAME, "Backup file written to server successfully...");
}
catch (Exception ex)
{
  Log.e(CommonStatic.LOG_NAME, "Backup File Upload Error: " + ex.getMessage(), ex);
  throw new Exception (c.getString(R.string.SAVE_TO_CLOUD_ERROR));
}

そして、これが私が受信するためにもう一方の端で使用しているPHPコードです:

$target = "userfiles/"; 
$target = $target . basename( $_FILES['uploadedfile']['name']);

if(move_uploaded_file($_FILES['uploadedfile']['tmp_name'], $target)) 
{ 
  echo "SUCCESS";
} 
else 
{ 
  echo "FAIL";
}

print_r($_FILES);$_FILES が実稼働インスタンスでは空であるが、テスト インスタンスでは空ではないことを確認するために、スクリプトの最初にa を貼り付けました。どんなアイデアでも大歓迎です。

4

1 に答える 1

2

残念ながら、この問題の直接的な解決策を見つけることはできませんでしたが、回避策を見つけることができました。を使用する代わりに、以前に試した を使用しましたが、成功しませんでしたconn.setChunkedStreamingModeconn.setFixedLengthStreamingMode入手の鍵conn.setFixedLengthStreamingMode機能するには、送信しようとしているデータ (この場合はファイル) の全長とヘッダーの長さを渡すことです。幸いなことに、ヘッダーの長さは通常、このようなコードでは固定されているため、ヘッダーがどれだけ大きいかを把握したら (Content-Disposition の下のヘッダーで送信されるファイル名なども可変であることを覚えておいてください)、そのまま配置できます。固定数として入力します。ヘッダーの長さを把握するために、最初にヘッダーの長さを指定せずにコードを実行しました。返されたエラー メッセージには、送信されたバイト数の予想値と実際の値が示され、ヘッダーの長さを計算することができました。

于 2012-09-18T01:40:01.117 に答える