场景:小米3G网络,系统默认开启了“节省流量”功能(关闭改功能上传文件是没问题的,WIFI上传也没问题)
发现上传文件的时候会出现,com.android.volley.TimeoutError,附件是上传了,但没有等到服务器返回,连接就中断了,TimeoutError,试着去修改socket超时时间,在自定义的Request中重载
public static final long SOCKET_TIMEOUT=1000*30;
@Override
public RetryPolicy getRetryPolicy() {
// TODO Auto-generated method stub
return new DefaultRetryPolicy(SOCKET_TIMEOUT, 0,
DefaultRetryPolicy.DEFAULT_BACKOFF_MULT);
}
失败!
于是改写这样:也就是在new Request之后设置
multipartRequest.setRetryPolicy(new DefaultRetryPolicy(
HttpUtil.SOCKET_TIMEOUT,
DefaultRetryPolicy.DEFAULT_MAX_RETRIES,
DefaultRetryPolicy.DEFAULT_BACKOFF_MULT));
multipartRequest.setTag(urlKey);
奇迹出来了,数据正常返回!
后来发现实际这个设置是有问题了,次数上传的数据会是两份,原因是因为我们有一次错误重试的机会导致的,这样修改:
multipartRequest.setRetryPolicy(new DefaultRetryPolicy(
HttpUtil.SOCKET_TIMEOUT, 0,
DefaultRetryPolicy.DEFAULT_BACKOFF_MULT));
搞定!