使用Apache HttpClient,为什么我的连接超时不起作用?

在调用doGetConnection()时,我的httpclient实现偶尔会抛出exception。 但是,我有以下超时设置

_moHttpClient.setHttpConnectionFactoryTimeout(30000); 

它看起来几乎像我的超时没有被拿起。 是否有其他我需要设置超时以确保不再发生此行为

你被抛出了什么例外?

不要忘记你有两次超时更改/检查。 来自HttpConnectionParams

 setConnectionTimeout() setSoTimeout() 

因此,您可以控制等待连接到服务器的时间,以及在超时之前对套接字执行的操作所需的时间。

  HttpConnectionManagerParams cmparams = new HttpConnectionManagerParams(); cmparams.setSoTimeout(10000); cmparams.setTcpNoDelay(true); HttpConnectionManager manager = new SimpleHttpConnectionManager(); manager.setParams(cmparams); params = new HttpClientParams(); params.setSoTimeout(5000); client = new HttpClient(params, manager); 

我想知道为什么我有两个不同的SoTimeout设置。 也许我试图找出哪一个实际上是活跃的,因为我在使用它时遇到了与你相同的问题。

以上是我们现在的实时代码,但我不能说它是否有效,因为它是正确的,或者因为天意对我微笑(而另一端通常是可用的)。

cmparams.setSoTimeout(10000);

这个默认情况下适用于所有HttpClient。

params.setSoTimeout(5000);

这个是针对特定的httpclient。