问题现象:
碰到一个问题,UI交互表现为:联通号码在3gwap网络环境下资源一直无法下载成功。
查看Log日志,打印出的信息为:ConnectTimeoutException: Connect to /10.0.0.172:80 timed out
则问题原因是:在使用了移动网关代理后出现超时,仍无法正确联网。
解决办法:
经观察,在同样的网络环境下,发现AIO缩略图片能正常接收,跟踪其代码发现该AIO缩略图在使用移动网络联网的步骤如下(感谢issac):
a. 首先判断网络环境,在移动网络及使用代理的情况,则对链接设置代理,并标识使用了代理
b. 发起链接
c. 在此处catch住连接超时异常(SocketTimeoutException/ConnectException),
如果发生了连接超时异常,则将此异常标识下来,尝试重新发起链接
d. 重新发起链接,如果在使用代理的情况下仍然发生了超时异常,则不使用代理,使用直连方式
(注:反映的3gwap联接失败的情况,采用代理失败了,但直连方式则正常连接成功了)
e. 直连方式仍发生异常,则取消直连方式,循环进入步骤a.
这是为了避免如果代理的设置本身是错误的,经用户修正后,保证仍可使用最新的代理联网成功。
f. 如果网络环境切换到了新的代理,则优先使用该代理进行步骤a的尝试。
经以上步骤,3gwap连网情况下,终于将使用直连方式时正常访问到网络资源。
碰到一个问题,UI交互表现为:联通号码在3gwap网络环境下资源一直无法下载成功。
查看Log日志,打印出的信息为:ConnectTimeoutException: Connect to /10.0.0.172:80 timed out
则问题原因是:在使用了移动网关代理后出现超时,仍无法正确联网。
解决办法:
经观察,在同样的网络环境下,发现AIO缩略图片能正常接收,跟踪其代码发现该AIO缩略图在使用移动网络联网的步骤如下(感谢issac):
a. 首先判断网络环境,在移动网络及使用代理的情况,则对链接设置代理,并标识使用了代理
b. 发起链接
c. 在此处catch住连接超时异常(SocketTimeoutException/ConnectException),
如果发生了连接超时异常,则将此异常标识下来,尝试重新发起链接
d. 重新发起链接,如果在使用代理的情况下仍然发生了超时异常,则不使用代理,使用直连方式
(注:反映的3gwap联接失败的情况,采用代理失败了,但直连方式则正常连接成功了)
e. 直连方式仍发生异常,则取消直连方式,循环进入步骤a.
这是为了避免如果代理的设置本身是错误的,经用户修正后,保证仍可使用最新的代理联网成功。
f. 如果网络环境切换到了新的代理,则优先使用该代理进行步骤a的尝试。
经以上步骤,3gwap连网情况下,终于将使用直连方式时正常访问到网络资源。