android

java.net.ProtocolException: unex

2018-07-04  本文已影响4人  孙科技

一种“unexpected end of stream”异常

此异常在使用OkHttp下载文件时出现 

特点1:必现; 

特点2:不是一开始出现,多出现在下载结尾处,并且每一次位置相同 

原因:http响应报文中,header中含有“content-length”,并且它的值比实际文件大,哪怕几个byte也不行,就会报上面的错误,所以请服务器修正这个错误吧;

代码如下:

longread = source.read(sink, Math.min(bytesRemaining, byteCount));if(read == -1) {    endOfInput(false);// The server didn't supply the promised content length.thrownewProtocolException("unexpected end of stream");}

当然unexpected end of stream还有其他产生的原因,这里只是其中之一;

注:同样的链接,用浏览器下载也不能下载完成,所以请保证content-length与实际大小保持一致

解决方案:

1、java.net.ProtocolException: unexpected end of stream 的出现,实现了一个RequestBody的上传包装进度的类。出现以上的问题。

搞了半天也不知啥原因,后来去掉了okhttp设置的logger拦截器,就可以了。无语。上传文件不能使用自带logger打印网络请求,打印网络请求不能上传文件。

2、if (bufferedSink == null) {

//包装

bufferedSink = Okio.buffer(sink(sink));

}

你把上面的if语句去掉就可以正常了

但是很多网上都是这样写的,目前不知道去掉有什么影响

上一篇 下一篇

猜你喜欢

热点阅读