您的位置:首页 > 编程语言 > Java开发

关于用java io实现文件压缩与解压(不涉及压缩算法)

2013-10-14 21:24 609 查看
最近,因为学习需要,去实现了下文件的压缩和解压,其实与其说是压缩与解压,不如说就是文件的合并。

原理很简单,就是把需要压缩的文件写到一个文件里,解压时则是读取文件中的原内容一次还原回各个文件夹。这个代码的关键就是需要用到DataInputstream,DataInputstream标准输入输出流。先通过对要压缩的文件夹进行递归遍历得到所有文件对象,再将各个文件写入新文件,而文件大小,名称,路径作为类似‘协议头’一并写入新文件。

读取时,只需先将‘协议头’逐个取出,再根据协议头,即可解压(还原)出原文件。

需要注意的是,文件内容写入和写出时,需要用到缓冲,可以用固定长度数组依次写入写出。原因是需要考虑到大数据的情况,如果全部加载进数组,肯定会对虚拟机造成很大的压力甚至导致其奔溃。

具体代码参考如下:

import java.io.BufferedInputStream;

  import java.io.BufferedOutputStream;

  import java.io.File;

  import java.io.FileInputStream;

  import java.io.FileOutputStream;

  import java.util.zip.ZipEntry;

  import java.util.zip.ZipOutputStream;

  public class Zip {

  static final int BUFFER = 2048;

  public static void main(String argv[]) {

  try {

  BufferedInputStream origin = null;

  FileOutputStream dest = new FileOutputStream("E:\\test\\myfiles.zip");

  ZipOutputStream out = new ZipOutputStream(new BufferedOutputStream(

  dest));

  byte data[] = new byte[BUFFER];

  File f = new File("e:\\test\\a\\");

  File files[] = f.listFiles();

  for (int i = 0; i < files.length; i++) {

  FileInputStream fi = new FileInputStream(files[i]);

  origin = new BufferedInputStream(fi, BUFFER);

  ZipEntry entry = new ZipEntry(files[i].getName());

  out.putNextEntry(entry);

  int count;

  while ((count = origin.read(data, 0, BUFFER)) != -1) {

  out.write(data, 0, count);

  }

  origin.close();

  }

  out.close();

  } catch (Exception e) {

  e.printStackTrace();

  }

  }

  }

  解压缩的

  import java.io.BufferedInputStream;

  import java.io.BufferedOutputStream;

  import java.io.File;

  import java.io.FileOutputStream;

  import java.util.Enumeration;

  import java.util.zip.ZipEntry;

  import java.util.zip.ZipFile;

  public class UnZip {

  static final int BUFFER = 2048;

  public static void main(String argv[]) {

  try {

  String fileName = "E:\\test\\myfiles.zip";

  String filePath = "E:\\test\\";

  ZipFile zipFile = new ZipFile(fileName);

  Enumeration emu = zipFile.entries();

  int i=0;

  while(emu.hasMoreElements()){

  ZipEntry entry = (ZipEntry)emu.nextElement();

  //会把目录作为一个file读出一次,所以只建立目录就可以,之下的文件还会被迭代到。

  if (entry.isDirectory())

  {

  new File(filePath + entry.getName()).mkdirs();

  continue;

  }

  BufferedInputStream bis = new BufferedInputStream(zipFile.getInputStream(entry));

  File file = new File(filePath + entry.getName());

  //加入这个的原因是zipfile读取文件是随机读取的,这就造成可能先读取一个文件

  //而这个文件所在的目录还没有出现过,所以要建出目录来。

  File parent = file.getParentFile();

  if(parent != null && (!parent.exists())){

  parent.mkdirs();

  }

  FileOutputStream fos = new FileOutputStream(file);

  BufferedOutputStream bos = new BufferedOutputStream(fos,BUFFER);

  int count;

  byte data[] = new byte[BUFFER];

  while ((count = bis.read(data, 0, BUFFER)) != -1)

  {

  bos.write(data, 0, count);

  }

  bos.flush();

  bos.close();

  bis.close();

  }

  zipFile.close();

  } catch (Exception e) {

  e.printStackTrace();

  }

  }

  }
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  io 压缩 递归