用户操作
[即时聊天] [发私信] [加为好友]
曾巧ID:numenZQ
42207次访问,排名2821,好友0人,关注者0人。
numenZQ的文章
原创 29 篇
翻译 16 篇
转载 2 篇
评论 16 篇
最近评论
xh:不推荐修改web.xml,设置java_options更好
numenZQ:补充说明一点,使用java.util.zip包时,是以UTF-8编码格式读取的文件名,因此在中文windows操作系统(Windows操作系统默认字符集为:GBK)中使用时会导致文件名解析错误,因此需要使用org.apache.tools.zip.ZipEntry和 org.apache.tools.zip.ZipOutputStream类来解决这一问题。
numenZQ:这个是需要明确知道字符串的成分,该方法只是为了满足读取不同字符集相应字符串,还是以“多哈亚运会”为例:如果字符集为GBK,截取前6个字节,结果为:“多哈亚”;当字符集为UTF-8时,截取前6个字节,结果则为:“多哈”,这是因为GBK是双字节编码,而UTF-8是三字节变长编码,如果不分字符集来读取对应长度的字串,则会出现字串内容与预期不符,长度错误等问题。
lyazure:仔细看了你的代码,作用是从一个字符串中获取指定字节数的字符,不知道你要这么做的最终目的是用来做什么。除非明确知道字符串的成分,否则这种做法很难做到完美,比如你的代码中,假如出现要从“多哈亚运会”这样的字符串中截取7个字节,最终会截得3个字符。
Alexandre:ab8e44bc75204d49bf0c9fe68a2b2176 matura foto amatoriale
收藏
    相册
    存档
    软件项目交易
    订阅我的博客
    XML聚合  FeedSky
    订阅到鲜果
    订阅到Google
    订阅到抓虾
    订阅到BlogLines
    订阅到Yahoo
    订阅到GouGou
    订阅到飞鸽
    订阅到Rojo
    订阅到newsgator
    订阅到netvibes

    原创 Java处理Zip文件收藏

    新一篇: 解析Selenium | 旧一篇: CruiseControl基础配置

    作者:曾巧(numenzq

     

        最近做的一个项目需要用Java程序读写Zip文件,迫于找不到好的工具类来处理,也只好用java.util.zip包提供的类来实现Zip文件的压缩和解压操作了,在这之前你需要了解以下几个基本概念:

    •     ZipEntryThis class is used to represent a ZIP file entry.
    •     ZipFileThis class is used to read entries from a zip file.
    •     ZipInputStreamThis class implements an input stream filter for reading files in the ZIP file format.
    •     ZipOutputStreamThis class implements an output stream filter for writing files in the ZIP file format.

     

    现在我们了解一下读写Zip文件的基本流程。当解压时,从该Zip文件输入流中读取出ZipEntry,然后根据ZipEntry的信息,读取对应文件的相应字节。代码实现如下:

     

    public synchronized static Map<String, byte[]> unZip(InputStream is)

               throws IOException {

     

           Map<String, byte[]> result = new HashMap<String, byte[]>();

          

           byte[] buf;

           ZipInputStream zis = new ZipInputStream(is);

           ZipEntry zipEntry = zis.getNextEntry();

     

           while (zipEntry != null) {

     

               if (zipEntry.isDirectory()) {

     

                  zipEntry = zis.getNextEntry();

                  continue;

               } else {

     

                  buf = new byte[(int) zipEntry.getSize()];

                  zis.read(buf, 0, (int) zipEntry.getSize());

                   result.put(zipEntry.getName(), buf);

     

                  zipEntry = zis.getNextEntry();

               }

           }

     

           return result;

    }

     

    压缩操作与解压操作差不多,先将文件字节流组装成ZipEntry,然后把ZipEntry加入到输出流中即可。代码实现如下:

     

    public synchronized static ByteArrayOutputStream zip(Map<String, byte[]> map)

               throws IOException {

     

           ByteArrayOutputStream baos = new ByteArrayOutputStream();

           ZipOutputStream zos = new ZipOutputStream(baos);

           ZipEntry zipEntry;

     

           for (String key : map.keySet()) {

     

               zipEntry = new ZipEntry(key);

               zipEntry.setSize(map.get(key).length);

               zipEntry.setTime(System.currentTimeMillis());

     

               zos.putNextEntry(zipEntry);

               zos.write(map.get(key));

               zos.flush();

           }

           zos.close();

           return baos;

        }

       

        至此,使用上面的两个方法就能完成基本的Zip文件压缩和解压缩处理了;该方法只适合处理Zip格式的文件,对于GZip格式的文件,我相信你也能轻松搞定了:)。

    发表于 @ 2007年08月16日 13:20:00|评论(loading...)|编辑

    新一篇: 解析Selenium | 旧一篇: CruiseControl基础配置

    评论

    #numenZQ 发表于2007-10-09 16:30:46  IP: 221.130.180.*
    补充说明一点,使用java.util.zip包时,是以UTF-8编码格式读取的文件名,因此在中文windows操作系统(Windows操作系统默认字符集为:GBK)中使用时会导致文件名解析错误,因此需要使用org.apache.tools.zip.ZipEntry和 org.apache.tools.zip.ZipOutputStream类来解决这一问题。
    发表评论  


    登录
    Csdn Blog version 3.1a
    Copyright © numenzq