を使用してサーバーに接続しようとしていますHttpURLConnection
が、PUT メソッドに問題があります。1500 文字
(またはそれ以上) の文字
列を送信する必要がありますが、この場合、サーバーはタイムアウトを生成し、500 - server internal errorを返します。1400 文字
未満の文字列を送信しても問題はなく、サーバーはOKを返します。
私のコードは次のとおりです。
public String connectToServer(String prototype) {
String responseString = "";
try {
BufferedReader in = new BufferedReader(new InputStreamReader(openURLForInput(new URL(URL), USERNAME, PASSWORD, prototype)));
String line;
while ((line = in.readLine()) != null) {
System.out.println(line);
responseString += line;
}
} catch (IOException e) {
e.printStackTrace();
responseString = e.toString();
}
return responseString;
}
//-------------------------------------
public InputStream openURLForInput(URL url, String uname, String pword, String content) throws IOException {
HttpURLConnection conn = (HttpURLConnection) url.openConnection();
conn.setDoInput(true);
conn.setDoOutput(true);
conn.setRequestProperty("Authorization", userNamePasswordBase64(uname, pword)); // I know this is OK
conn.addRequestProperty("Content-type", "application/xml; charset=utf-8");
//conn.setChunkedStreamingMode(8 * 1024);
conn.setRequestMethod("PUT");
conn.connect();
OutputStream output = conn.getOutputStream();
OutputStreamWriter osw = new OutputStreamWriter(output, "UTF-8");
BufferedWriter writer = new BufferedWriter(osw);
writer.write(content); // content length > 1400 characters
writer.close();
output.close();
int status = conn.getResponseCode();
Log.i("STATUS", status + "");
Log.i("STATUS_ERROR", conn.getResponseMessage());
return conn.getInputStream();
}
行を追加してみました
conn.setFixedLengthStreamingMode(contentLength)
conn.setChunkedStreamingMode(8 * 1024);
しかし、とにかくサーバーの答えは間違っています。
アップデート:
問題を検出できました。何らかの理由で、リクエストで大きな本文を送信しようとすると、サーバーはタイムアウトを生成しますが、すべてのネットワークではなく、一部のネットワークでのみ生成されます。安全な接続 SSL を使用していますが、問題が発生する可能性がありますか?