Java cURL可以工作,但在Apache';HttpComponents库没有?

Java cURL可以工作,但在Apache';HttpComponents库没有?,java,php,curl,apache-httpcomponents,Java,Php,Curl,Apache Httpcomponents,为了这个小问题,我已经好几天了。希望这里有人能发现我的错误(因为我相信这是我的错),并就如何补救给我几点意见。如果我的解释不成功,请告诉我,我会尝试以更简洁的方式重写它 -- 一点背景:作为一个小型项目的一部分,我一直在编写一个Java应用程序来监视浏览器内游戏发送的聊天和事件数据(供参考)。遗憾的是,关于他们的web服务如何工作的文档并不多,但我已经设法拼凑了一系列请求(基于观察网络流量和其他开发人员发布的代码示例)来处理登录等 一个特定的请求绝对拒绝完成,Java在暂停30秒后抛出连接重置异

为了这个小问题,我已经好几天了。希望这里有人能发现我的错误(因为我相信这是我的错),并就如何补救给我几点意见。如果我的解释不成功,请告诉我,我会尝试以更简洁的方式重写它

--

一点背景:作为一个小型项目的一部分,我一直在编写一个Java应用程序来监视浏览器内游戏发送的聊天和事件数据(供参考)。遗憾的是,关于他们的web服务如何工作的文档并不多,但我已经设法拼凑了一系列请求(基于观察网络流量和其他开发人员发布的代码示例)来处理登录等

一个特定的请求绝对拒绝完成,Java在暂停30秒后抛出连接重置异常。下面是此特定请求的连接日志

 2014/03/25 11:17:16:703 EDT [DEBUG] RequestAddCookies - CookieSpec selected: best-match
 2014/03/25 11:17:16:703 EDT [DEBUG] RequestAuthCache - Auth cache not set in the context
 2014/03/25 11:17:16:703 EDT [DEBUG] PoolingHttpClientConnectionManager - Connection request: [route: {s}->https://gamecdnorigin.alliances.commandandconquer.com:443][total kept alive: 1; route allocated: 0 of 2; total allocated: 1 of 20]
 2014/03/25 11:17:16:703 EDT [DEBUG] PoolingHttpClientConnectionManager - Connection leased: [id: 2][route: {s}->https://gamecdnorigin.alliances.commandandconquer.com:443][total kept alive: 1; route allocated: 1 of 2; total allocated: 2 of 20]
 2014/03/25 11:17:16:703 EDT [DEBUG] MainClientExec - Opening connection {s}->https://gamecdnorigin.alliances.commandandconquer.com:443
 2014/03/25 11:17:16:755 EDT [DEBUG] HttpClientConnectionOperator - Connecting to gamecdnorigin.alliances.commandandconquer.com/212.100.228.211:443
 *snip: 30 seconds of junk output*
 2014/03/25 11:18:16:992 EDT [DEBUG] DefaultManagedHttpClientConnection - http-outgoing-2: Shutdown connection
 2014/03/25 11:18:16:992 EDT [DEBUG] MainClientExec - Connection discarded
 2014/03/25 11:18:16:993 EDT [DEBUG] DefaultManagedHttpClientConnection - http-outgoing-2: Close connection
 2014/03/25 11:18:16:993 EDT [DEBUG] PoolingHttpClientConnectionManager - Connection released: [id: 2][route: {s}->https://gamecdnorigin.alliances.commandandconquer.com:443][total kept alive: 1; route allocated: 0 of 2; total allocated: 1 of 20]
 2014/03/25 11:18:16:993 EDT [INFO] RetryExec - I/O exception (java.net.SocketException) caught when processing request to {s}->https://gamecdnorigin.alliances.commandandconquer.com:443: Connection reset
 2014/03/25 11:18:16:993 EDT [DEBUG] RetryExec - Connection reset <java.net.SocketException: Connection reset>java.net.SocketException: Connection reset
    at java.net.SocketInputStream.read(SocketInputStream.java:189)
    at java.net.SocketInputStream.read(SocketInputStream.java:121)
    at sun.security.ssl.InputRecord.readFully(InputRecord.java:465)
    at sun.security.ssl.InputRecord.read(InputRecord.java:503)
    at sun.security.ssl.SSLSocketImpl.readRecord(SSLSocketImpl.java:954)
    at sun.security.ssl.SSLSocketImpl.performInitialHandshake(SSLSocketImpl.java:1343)
    at sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1371)
    at sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1355)
    at org.apache.http.conn.ssl.SSLConnectionSocketFactory.createLayeredSocket(SSLConnectionSocketFactory.java:275)
    at org.apache.http.conn.ssl.SSLConnectionSocketFactory.connectSocket(SSLConnectionSocketFactory.java:254)
    at org.apache.http.impl.conn.HttpClientConnectionOperator.connect(HttpClientConnectionOperator.java:117)
    at org.apache.http.impl.conn.PoolingHttpClientConnectionManager.connect(PoolingHttpClientConnectionManager.java:314)
    at org.apache.http.impl.execchain.MainClientExec.establishRoute(MainClientExec.java:363)
    at org.apache.http.impl.execchain.MainClientExec.execute(MainClientExec.java:219)
    at org.apache.http.impl.execchain.ProtocolExec.execute(ProtocolExec.java:195)
    at org.apache.http.impl.execchain.RetryExec.execute(RetryExec.java:86)
    at org.apache.http.impl.execchain.RedirectExec.execute(RedirectExec.java:108)
    at org.apache.http.impl.client.InternalHttpClient.doExecute(InternalHttpClient.java:186)
    at org.apache.http.impl.client.CloseableHttpClient.execute(CloseableHttpClient.java:82)
    at org.apache.http.impl.client.CloseableHttpClient.execute(CloseableHttpClient.java:106)
 *snip: lots of extra backtrace*
cURL通过PHP:


为了使这篇文章尽可能简短(因为它已经是一堵令人痛苦的长长的文本墙),我稍微重写了PHP以显示$cookie和$data的值,因为这两个值都是在脚本的执行过程中进一步设置的


任何帮助都将不胜感激。我不知道HttpComponents是否会在请求中添加或删除头数据(我2天前刚开始学习这个库,当时我开始学习这个项目),而cURL不会。如果有必要,我可以发布更多的代码示例,因为在这个项目中,除了从服务器返回的我的个人登录/会话信息之外,没有什么是真正的“秘密”。另外,这是我第一次来这里D:因此,如果我没有正确格式化某些内容,或者如果我的代码段没有正确突出显示,请告诉我,我会尽力修复它:)

尝试通过关闭您获得的可关闭实例来关闭基础连接

CloseableHttpResponse resp = ApiCommunicator.getHttpClient().execute(post);
try {
        System.out.println(EntityUtils.toString(resp.getEntity()));
    } catch (Exception e) {
        e.printStackTrace();
    }
    finally{
       resp.close();
    }

我建议您使用命令行选项-Djavax.net.debug=ssl运行java客户机,因为这将使您对ssl握手有更多(但神秘)的了解。这应该会说明潜在的连接问题,但可能需要一段时间才能理解此调试日志将输出的详细信息。提供了关于SSL握手的非常详细的讨论

您的HTTPClient没有定义良好的SSLContext似乎是合理的。您可以探索使用其中一些选项来创建它

SSLContext sslContext = SSLContexts.createDefault();
SSLConnectionSocketFactory sslSocketFactory = new SSLConnectionSocketFactory(sslContext, SSLConnectionSocketFactory.ALLOW_ALL_HOSTNAME_VERIFIER);
CloseableHttpClient httpClient = HttpClients.custom().setSSLSocketFactory(sslSocketFactory).build();

请注意,您还可以从SSLContexts.custom()创建自定义SSLContext,它允许您添加密钥库、信任库和使用TLS指定

问题不在于没有达成协议。这个特殊的请求永远不会超过“连接到gamecdnorigin.alliances.commandconquer.com/212.100.228.211:443”阶段。我需要在这里添加close语句,是的,但我认为这不是我现在的问题。我不熟悉curl,所以我将在这里停止,因为我不知道如何比较这两个输出。不过我建议使用一个工具,例如“wireshark”,记录从curl和java发出的请求。然后,您可以对它们进行比较,以查看每个文件中实际发送的内容。您可能会发现字符串中的差异等,这也可能导致服务器拒绝来自java端的连接。我一直在使用Wireshark检查cURL请求和从java发送的请求所建立的连接,但两者之间的唯一区别似乎是,Java发送的一条消息以服务器的连接重置结束。现在,我没有太多与Wireshark合作的经验(前一段时间我在当地IT团队实习了一小段时间),所以很可能我误读了输出。有什么建议吗?
SSLContext sslContext = SSLContexts.createDefault();
SSLConnectionSocketFactory sslSocketFactory = new SSLConnectionSocketFactory(sslContext, SSLConnectionSocketFactory.ALLOW_ALL_HOSTNAME_VERIFIER);
CloseableHttpClient httpClient = HttpClients.custom().setSSLSocketFactory(sslSocketFactory).build();