6

我的一些用户在尝试连接时经常遇到此异常。

java.io.IOException: Unexpected response code for CONNECT: 400
    at libcore.net.http.HttpsURLConnectionImpl$HttpsEngine.makeTunnel(HttpsURLConnectionImpl.java:509)
    at libcore.net.http.HttpsURLConnectionImpl$HttpsEngine.makeSslConnection(HttpsURLConnectionImpl.java:463)
    at libcore.net.http.HttpsURLConnectionImpl$HttpsEngine.connect(HttpsURLConnectionImpl.java:442)
    at libcore.net.http.HttpEngine.sendSocketRequest(HttpEngine.java:290)
    at libcore.net.http.HttpEngine.sendRequest(HttpEngine.java:240)
    at libcore.net.http.HttpURLConnectionImpl.connect(HttpURLConnectionImpl.java:81)
    at libcore.net.http.HttpsURLConnectionImpl.connect(HttpsURLConnectionImpl.java:165)

400 表示错误的请求,但相同的请求在几秒钟后成功。我仔细检查了请求,没有任何问题。我也检查了服务器日志,似乎请求甚至没有到达我们的服务器。

我正在使用一个简单HttpUrlConnection的连接。

URL connectURL = new URL(url);
HttpURLConnection conn = (HttpURLConnection) connectURL.openConnection();
conn.setDoInput(true);
conn.setDoOutput(true);
conn.setUseCaches(false);
conn.setInstanceFollowRedirects(true);
conn.setReadTimeout(30000); 
conn.setConnectTimeout(15000);
conn.setRequestMethod("POST");

connection.setRequestProperty("Content-Type", "application/x-www-form-urlencoded");
connection.setRequestProperty("Accept-Encoding", "deflate, gzip");
connection.setRequestProperty("Content-Length", postParameters.length() + "");

conn.connect();

OutputStreamWriter writer = new OutputStreamWriter(conn.getOutputStream());
writer.write(mRequestObj.getPostParameters());
writer.flush();
writer.close();

responseCode = conn.getResponseCode();

BufferedInputStream bis = null;
try {
    bis = new BufferedInputStream(conn.getInputStream());
}
catch(IOException io) {
    if(conn.getErrorStream() != null) 
        bis = new BufferedInputStream(conn.getErrorStream());
    else 
        throw io;
}

... 

还有其他人遇到过这个问题吗?有什么可以帮助的吗?

4

1 回答 1

1

这是一个老问题,但也许有人会觉得它有帮助。

由于代理隧道由于某种原因失败,引发异常。这就是为什么您的网络服务器什么也没显示,根本没有到达。


以下描述涉及 CONNECT 方法类型:

本规范保留方法名称 CONNECT 与可以动态切换为隧道的代理一起使用

它是从HTTP 规范复制而来的。


不幸的是,除非您可以控制代理服务器,否则您无能为力。您可以做的是捕获异常并重试连接。

于 2014-08-13T18:24:57.380 回答