java.net.ProtocolException: unex
一种“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语句去掉就可以正常了
但是很多网上都是这样写的,目前不知道去掉有什么影响