これが私が遭遇しているものです。
/**
* Perform a post while retrieving an object in return.
* @param urlPath path to requested resource
* @param obj object to post
* @return object retrieved from server
*/
private Object doPostGet(String urlPath, Object obj) {
try {
URL url = new URL("http://" + this.host + ":" + this.port + urlPath);
HttpURLConnection con = (HttpURLConnection) url.openConnection();
con.setRequestMethod("POST");
con.setRequestProperty("Accept", "text/xml");
con.setRequestProperty("Accept", "text/plain");
con.setDoInput(true);
con.setDoOutput(true);
con.connect();
xStream.toXML(obj, con.getOutputStream());
con.getOutputStream().close();
Object outObj = null;
if (con.getResponseCode() == Handler.OK) {
InputStream in = new BufferedInputStream(con.getInputStream());
assert in != null;
outObj = xStream.fromXML(in);
in.close();
} else if (con.getResponseCode() == Handler.FAILED_AUTH) {
//
} else if (con.getResponseCode() == Handler.BAD_REQUEST) {
//
}
con.disconnect();
return outObj;
} catch (SocketException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
return null;
}
java.net.SocketException: Unexpected end of file from server
at sun.net.www.http.HttpClient.parseHTTPHeader(HttpClient.java:718)
at sun.net.www.http.HttpClient.parseHTTP(HttpClient.java:579)
at sun.net.www.http.HttpClient.parseHTTPHeader(HttpClient.java:715)
at sun.net.www.http.HttpClient.parseHTTP(HttpClient.java:579)
at sun.net.www.protocol.http.HttpURLConnection.getInputStream(HttpURLConnection.java:1322)
at java.net.HttpURLConnection.getResponseCode(HttpURLConnection.java:468)
at mock.communicator.Communicator.doPostGet(Communicator.java:131)
at mock.communicator.Communicator.main(Communicator.java:102)
Communicatorの131行目は「if (con.getResponseCode() == Handler.OK) {」です。何が原因なのかよくわかりません。また、このようなことは初めてなので、理解が限られています。私が間違っていることを理解するのを手伝ってくれたら、それは素晴らしいことです。サーバー側のコードが必要な場合はお知らせください。HttpHandlers を使用して独自の HttpServer を実行しています。