java – 当jar文件从URL打开为InputStream时,JarEntry.getSize()返回-1

前端之家收集整理的这篇文章主要介绍了java – 当jar文件从URL打开为InputStream时,JarEntry.getSize()返回-1前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我试图从JarInputStream读取文件,文件的大小返回-1.我正在从URL访问Jar文件作为inputStream.
  1. URLConnection con = url.openConnection();
  2.  
  3. JarInputStream jis = new JarInputStream(con.getInputStream());
  4. JarEntry je = null;
  5.  
  6. while ((je = jis.getNextJarEntry()) != null) {
  7. htSizes.put(je.getName(),new Integer((int) je.getSize()));
  8. if (je.isDirectory()) {
  9. continue;
  10. }
  11. int size = (int) je.getSize();
  12. // -1 means unknown size.
  13. if (size == -1) {
  14. size = ((Integer) htSizes.get(je.getName())).intValue();
  15. }
  16. byte[] b = new byte[(int) size];
  17. int rb = 0;
  18. int chunk = 0;
  19. while (((int) size - rb) > 0) {
  20. chunk = jis.read(b,rb,(int) size - rb);
  21. if (chunk == -1) {
  22. break;
  23. }
  24. rb += chunk;
  25. }
  26. // add to internal resource hashtable
  27. htJarContents.put(je.getName(),baos.toByteArray());
  28. }

解决方法

这是记录在案的行为. Javadoc说getSize()……

“Returns the uncompressed size of the entry data,or -1 if not known.”

显然,这是未知压缩数据的实际大小的情况.您的应用程序只需处理此问题.

跟进

评论了另一个答案:

Though we have the total content size,i think with out having the individual file size we can’t read the files.

如果你没有这个大小,你仍然可以读取文件并使用ByteArrayOutputStream缓冲它,然后调用toByteArray()以将缓冲的字节提取为byte [].事实上,鉴于(根据Tom Hawtin的评论),报告的大小可能不正确,无论如何你可能应该这样做,只需将报告的大小视为提示……并将其用作ByteArrayOutputStream的初始容量.

(顺便提一下,你的问题中的代码看起来可能是以这种方式工作……从第2行到最后一行判断.问题是代码的其余部分不使用baos对象.)

猜你在找的Java相关文章