gpt4 book ai didi

java - Android:URLConnection.getContentLength() 给出不正确的值

转载 作者:塔克拉玛干 更新时间:2023-11-02 23:05:24 26 4
gpt4 key购买 nike

我正在尝试使用以下方法获取 URL 内容的大小:

URLConnection conn = null;
URL url = null;
url = new URL("https://dl.dropboxusercontent.com/u/90210205/Default.html");
conn = url.openConnection();
conn.connect();
InputStream in = new BufferedInputStream(url.openStream());
int fileSize = conn.getContentLength();
System.out.println("File size " + fileSize);
while (in.read() != -1) {
i++;
}
in.close();
System.out.println("Read " + i + " bytes of a possible " + fileSize);

我在 AsyncTaskdoInBackground() 中使用它,出于某种原因 conn.getContentLength(); 正在返回 1273 当它应该返回 10136 时。

我在常规 Java 应用程序的 Main 中使用了上述代码,conn.getContentLength(); 返回了正确的 10136 值。

为什么它不能在 AsyncTask 中工作?

最佳答案

.getContentLength()的描述是返回Content-Length头字段的值。在一般情况下,这应该与可供读取的数据量相匹配。然而……

(1) 如果使用分块编码发送数据,则 header 可能不存在。在这种情况下,.getContentLength() 返回 -1,所以这里似乎不是这种情况。

(2) 默认情况下,HttpURLConnection 的实现请求服务器使用 gzip 压缩,它会自动为 getInputStream() 的调用者解压缩数据。在这种情况下,Content-Encoding 和 Content-Length 响应 header 被清除。

最后一句话似乎表明这里也不是这种情况,因为您没有从 .getContentLength()` 获得 -1,但相对大小 (1273/10136) 让我可疑的……

对此的一个测试是通过在请求 header 中设置可接受的编码来禁用 Gzip 编码:

urlConnection.setRequestProperty("Accept-Encoding", "identity");

另一种方法是“窥探”网络流量以观察 http header 和数据量以获取线索。

顺便说一句,url.openStream()url.openConnection().getInputStream() 提供了便利。

关于java - Android:URLConnection.getContentLength() 给出不正确的值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18634970/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com