关于setConnectTimeout和setReadTimeout的问题

1、问题描述

因为用户登录记录需要记录登录地址,这个地址获取调用的是阿里的接口,登录的时候由于connect没有响应,造成一直卡在登录界面。

2、问题排查和定位

思考:网络差不应该报网络异常的错误或者直接抛timeout异常吗?所以马上去检查Http请求的地方.

备注:(在DownloadThread中使用 HttpURLConnection进行网络请求时 只是设置了connectTimeout,这样在建立连接的时候如果网络中断,那么超时以后就会报出错误,这里是没有问题的。会不会是还少设置了其他参数的原因呢?)

于是赶紧去查阅资料:
ConnectTimeout只有在网络正常的情况下才有效,而当网络不正常时,ReadTimeout才真正的起作用,即IdIOHandlerStack 里的 WaitFor 是受ReadTimeout限制的,因此,这2个属性应该结合实用。

connect timeout 是建立连接的超时时间;
read timeout, 是传递数据的超时时间。

正确的方法应当是调用HttpURLConnection的时候同时设置这两个超时时间。
一看代码,果然漏了setReadTimeout。。。。。OMG 。。。

3、解决方案

同时设置这两个超时时间:
URLConnection connection = url.openConnection();
connection.setConnectTimeout(5000); // 5秒 连接主机的超时时间(单位:毫秒)
connection.setReadTimeout(5000); // 5秒 从主机读取数据的超时时间(单位:毫秒)
参考:https://blog.csdn.net/jackson_wen/article/details/51923514

你可能感兴趣的:(URLConnection)