1

我们使用 Unirest 1.5.4 for java。我们的服务器以 204 - NO_CONTENT 状态和空响应正文响应 DELETE 调用。当我进行同步删除调用时,以下调用将以 SocketTimeoutException 结束。

为了进行更深入的调查,我在服务器中交换了一些行以响应状态 200 和“{}”正文。只有使用此服务器端 hack Unirest 才能正常工作。

这是我的(失败的)Unirest 客户端代码:

public static void main(String... args) throws UnirestException {
    String baseUrl = "http://localhost:9010/orga/";
    String orgaJson = "{}";
    HttpResponse<String> postResponse = Unirest.post(baseUrl).body(orgaJson).asString();
    System.out.println("POST status = " + postResponse.getStatus());
    JSONObject orga = new JSONObject(postResponse.getBody());
    String orgaId = orga.getJSONObject("_id").getString("$oid");
    HttpResponse<String> deleteResponse = Unirest.delete(baseUrl+"{id}").routeParam("id", orgaId).asString();
    System.out.println("DELETE status = " + deleteResponse.getStatus());
    System.out.println("DELETE body = " + deleteResponse.getBody());
    // the next call will cause a SocketTimeoutException
    Unirest.post(baseUrl).body(orgaJson).asString();
}
4

1 回答 1

0

我设法通过将超时设置为略高于默认值来解决类似的问题。看起来如果您尝试与 MailChimp 之类的服务建立多个连接,则每个后续请求都会花费更多时间。尝试一下。

Unirest.setTimeouts(10000, 30000);
于 2015-10-13T08:14:32.863 回答