关于用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();
}
}
}
原理很简单,就是把需要压缩的文件写到一个文件里,解压时则是读取文件中的原内容一次还原回各个文件夹。这个代码的关键就是需要用到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();
}
}
}
相关文章推荐
- java实现将ZIP压缩文件解压的工具类
- java实现的文件压缩和解压
- Java实现文件压缩与解压的示例[zip格式,gzip格式]
- Java实现文件压缩与解压[zip格式,gzip格式]
- java中对文件解压和压缩的实现
- Java 中调用 Apache API 实现图片文件的 压缩 与 解压 实例
- java代码实现加密压缩文件解压
- Java实现文件的压缩与解压
- java程序实现对文件的压缩和解压
- JAVA自己实现的文件压缩解压
- Java实现文件压缩与解压[zip格式,gzip格式]
- java实现文件压缩和解压
- java实现将ZIP压缩文件解压的工具类
- 用java代码实现文件的zip压缩与解压
- Java实现文件压缩与解压[zip格式,gzip格式]
- java实现zip文件压缩,解压
- JAVA 解压压缩包中指定文件或实现压缩文件的预览及下载单个或多个指定的文件
- JAVA 实现文件(字符串)压缩与解压
- Java实现文件压缩与解压[zip格式,gzip格式]
- java实现linux中gzip压缩解压缩算法:byte[]字节数组,文件,字符串,数据流的压缩解压缩