利用okhttp下载文件时,文件大小无法获取,可能有的说通过
一、requestBuilder.addHeader(“Accept-Encoding”, “identity”),因为okhttp源码中,当未添加Accept-Encoding时,默认使用的为gzip格式,然后通过contentLength,然而并无效,说明此方法不通
二、直接通过response.body().byteStream().avalable(),但是让你失望的是,返回的是0,因为还没下载完,所以返回的很可能是0,此法行不通
三、也就是下面的操作方法
四、String.format("%1s?appId=%2s&plaformType=%3s&environment=%4s", url, queryDto.getAppId(), queryDto.getPlaformType(), queryDto.getEnvironment());
一个有效可行的操作是,执行两次请求
第一次请求,http请求还有一个head请求的方法,因此可先通过,request中添加head()进行请求,这个请求获取的是文件大小,不能通过该response执行下载操作
Request request = new Request.Builder()
.url(downloadUrl)
.head()
.build();
执行 Response response = client.newCall(request).execute();
在response中
String contentLength = response.header(“Content-Length”);
第二次请求,执行你要下载的文件路径
Request request = new Request.Builder()
.url(downloadUrl)
.get()
.build();
Response response = client.newCall(request).execute();
或者异步执行
Response response = client.newCall(request).enqueue(callback);
获取到文件的大小,接着就可以通过 response.body().byteStream()拿到inputstream,然后可以进行读取的操作了