Java http请求GET在浏览器中正常运行却超时异常

Java http request GET causes timeout exception while it works fine in the browser

我在 Java 中一直在玩 Http,我遇到了一个奇怪的问题。下面是执行 GET 方法的一段代码:

OkHttpClient client = new OkHttpClient();
client.setConnectTimeout(100, TimeUnit.SECONDS);
client.setReadTimeout(100, TimeUnit.SECONDS);
Response response = null;
Request request = new Request.Builder()
        .url("https://www.celebritycruises.com/")
        .get()
        .build();
try {
    response = client.newCall(request).execute();
    System.out.println(response.code());
} catch (IOException e) {
    e.printStackTrace();
} 

因此有一些网站(例如 Builder 中提供的网站,这导致:

java.net.SocketTimeoutException: timeout
at okio.Okio.newTimeoutException(Okio.java:207)
at okio.AsyncTimeout.exit(AsyncTimeout.java:261)
at okio.AsyncTimeout.read(AsyncTimeout.java:215)
[...]
Caused by: java.net.SocketTimeoutException: Read timed out
at java.net.SocketInputStream.socketRead0(Native Method)
at java.net.SocketInputStream.socketRead(SocketInputStream.java:116)
at java.net.SocketInputStream.read(SocketInputStream.java:171)
at java.net.SocketInputStream.read(SocketInputStream.java:141)
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:983)
at sun.security.ssl.SSLSocketImpl.readDataRecord(SSLSocketImpl.java:940)

at sun.security.ssl.AppInputStream.read(AppInputStream.java:105)
at okio.Okio.read(Okio.java:139)
at okio.AsyncTimeout.read(AsyncTimeout.java:211)
... 38 more

我不明白的是:为什么这在浏览器中工作正常?我已经为 100seconds 设置了 timeouts。我也尝试过其他 HttpClients,但结果相同(我相信在内心深处他们使用相同的 类 无论如何)。请问谁能告诉我问题出在哪里?

编辑

我尝试了 wget - 成功了,保存了一些 HTML 内容。 curl 返回:(52) Empty reply from server

您必须在请求中使用用户代理。这有效:

Request request = new Request.Builder().url("https://www.celebritycruises.com/").header("User-Agent", "Mozilla/5.0 (Windows NT 6.1; Win64; x64; rv:57.0) Gecko/20100101 Firefox/57.0").build();