【发布时间】:2020-11-08 18:06:29
【问题描述】:
这是我在这里的第一个问题,所以如果不是所有需要的信息都在这篇文章中,我深表歉意。
我遇到了 java.net.http.HttpClient 和 HttpServer 之间的通信问题。 我从带有 HttpClient 的应用程序向带有 Httpserver 的应用程序发送请求,后者读取该请求,根据消息中的信息发送邮件并使用 HttpClient 向应用程序发送响应,如果一切正常则成功,如果出现问题则失败。
前几次(随机多少次,有时 2 次有时 24 次)通常正确发送并由服务器正确处理,这导致 httpClient 接收响应“成功”,但服务器突然收到带有正确标头但没有正文的请求,即使请求中始终是同一条消息,这会导致“失败”响应。
我的 HttpClient:
private Boolean sendMail(String requestBody) throws IOException, InterruptedException {
HttpClient client = HttpClient.newBuilder()
.version(HttpClient.Version.HTTP_1_1)
.cookieHandler(CookieHandler.getDefault())
.build();
HttpRequest request = HttpRequest.newBuilder()
.uri(URI.create(this.uri))
.header("Content-Type", "application/json")
.POST(HttpRequest.BodyPublishers.ofString(requestBody))
.build();
//creating response body handler
HttpResponse.BodyHandler<String> bodyHandler = HttpResponse.BodyHandlers.ofString();
HttpResponse<String> response = client
.send(request, bodyHandler);
String requestOutcome = response.body();
System.out.println(requestOutcome);
我的 HttpServer:
HttpServer server = HttpServer.create(new InetSocketAddress(port), 0);
ThreadPoolExecutor threadPoolExecutor = (ThreadPoolExecutor) Executors.newFixedThreadPool(10);
server.createContext("/mial", new ServerHttpHandler(this.dbHandler, this.mailHandler));
server.setExecutor(threadPoolExecutor);
//Start HttpServer
server.start();
我的自定义 ServerHttpHandler:
public void handle(HttpExchange httpExchange) throws IOException {
String requestParamValue=null;
if("GET".equals(httpExchange.getRequestMethod())) {
requestParamValue = handleGetRequest(httpExchange);
}else if("POST".equals(httpExchange.getRequestMethod())) {
requestParamValue = handlePostRequest(httpExchange);
}
handleResponse(httpExchange,requestParamValue);
}
private String handleGetRequest(HttpExchange httpExchange) {
return httpExchange.
getRequestURI()
.toString()
.split("\\?")[1]
.split("=")[1];
}
private String handlePostRequest(HttpExchange httpExchange){
// get request
Headers reqHeaders = httpExchange.getRequestHeaders();
reqHeaders.forEach((key, value) -> System.out.println(key + ": " + value));
String message = null;
try (InputStream in = httpExchange.getRequestBody()) {
BufferedReader br = new BufferedReader(new InputStreamReader(in));
StringBuilder msgbuilder = new StringBuilder();
while (br.ready()) {
msgbuilder.append((char) br.read());
}
message = msgbuilder.toString();
System.out.println("Message: " + message);
br.close();
} catch (IOException e) {
e.printStackTrace();
}
return message;
}
private void handleResponse(HttpExchange httpExchange, String requestParamValue) throws IOException {
boolean success = this.convertMsgAndSendMail(requestParamValue);
String htmlResponse = "failure";
if(success) {
htmlResponse = "success";
}
httpExchange.sendResponseHeaders(200, htmlResponse.length());
OutputStream outputStream = httpExchange.getResponseBody();
outputStream.write(htmlResponse.getBytes());
outputStream.flush();
outputStream.close();
}
请求错误:
Connection: [Upgrade, HTTP1_1-Settings]
Http2-settings: [AAEAAEAAAAIAAAABAAMAAABkAAQBAAAAAAUAAEAA]
Host: [localhost:587]
Upgrade: [h2c]
User-agent: [Java-http-client/11.0.6]
Content-type: [application/json]
Content-length: [180]
Message:
所以标题每次都是相同的,但这次我没有收到任何消息。由于消息稍后转换为 JSON,我得到的唯一错误是消息不以“{”开头,因此它不是 Json 兼容的。
我在 StackOverflow 和其他网站上搜索了此问题的解决方案,但没有找到任何有用的提示来解决此问题。你有什么想法吗?
【问题讨论】:
标签: java http httpclient httpserver java-http-client