- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章ZIP4j 压缩与解压的实例详解由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
ZIP4j 压缩与解压的实例详解 。
使用的jar包:zip4j_1.3.2.jar 。
基本功能:
针对ZIP压缩文件创建、添加、分卷、更新和移除文件 (读写有密码保护的Zip文件) (支持AES 128/256算法加密) (支持标准Zip算法加密) (支持zip64格式) (支持Store(仅打包,默认不压缩,不过可以手动设置大小)和Deflate压缩方法 (针对分块zip文件创建和抽出文件) (支持编码) (进度监控) 。
压缩方式(3种)
1
2
3
|
static
final
int
COMP_STORE =
0
;(仅打包,不压缩) (对应好压的存储)
static
final
int
COMP_DEFLATE =
8
;(默认) (对应好压的标准)
static
final
int
COMP_AES_ENC =
99
;
|
压缩级别有5种:(默认0不压缩)级别跟好压软件是对应的; 。
1
2
3
4
5
|
static
final
int
DEFLATE_LEVEL_FASTEST =
1
;
static
final
int
DEFLATE_LEVEL_FAST =
3
;
static
final
int
DEFLATE_LEVEL_NORMAL =
5
;
static
final
int
DEFLATE_LEVEL_MAXIMUM =
7
;
static
final
int
DEFLATE_LEVEL_ULTRA =
9
;
|
加密方式:
1
2
3
|
static
final
int
ENC_NO_ENCRYPTION = -
1
;(默认,没有加密方法,如果采用此字段,会报错”没有提供加密算法”)
static
final
int
ENC_METHOD_STANDARD =
0
;
static
final
int
ENC_METHOD_AES =
99
;
|
AES Key Strength:
1
2
3
4
|
(默认-
1
,也就是ENC_NO_ENCRYPTION)
static
final
int
AES_STRENGTH_128 =
0x01
;
static
final
int
AES_STRENGTH_192 =
0x02
;
static
final
int
AES_STRENGTH_256 =
0x03
;
|
从构造方法可以默认情况:
1
2
3
4
5
6
7
|
compressionMethod = Zip4jConstants.COMP_DEFLATE;
encryptFiles =
false
;
//不设密码
readHiddenFiles =
true
;
//可见
encryptionMethod = Zip4jConstants.ENC_NO_ENCRYPTION;
//加密方式不加密
aesKeyStrength = -
1
;
//
includeRootFolder =
true
;
//
timeZone = TimeZone.getDefault();
//
|
发现的现象:
在采取默认压缩时:
1.如果此压缩文件已经存在,那么压缩后,相同的文件会替换(有密码,密码被替换),原来不同的文件会继续保留,而且文件的时间还是第一次压缩的时间;如果想完全覆盖,那么需要判断此压缩文件存不存在,存在就删除; 。
2.假如a文件加密生成了a.zip,此时如果再把其他的文件b也加密,然后生成同样的a.zip,那么a.zip里面的文件a,b将会有各自的密码。需要分别输入对应密码解压,无形实现了对单个文件的单个加密,但是这样解压可能会损坏文件(个人不建议这样做) 。
3.如果不设置压缩级别,默认级别为0(不压缩),这样生成的zip包跟原来文件的大小差不多,另外如果压缩方式设置成了Zip4jConstants.COMP_STORE(0)那么也是仅仅打个包; 。
4.如果设置了中文密码,用好压解压会提示密码错误(无法解压),用ZIP4j解压的话,正常;也就说,对于中文密码,解压软件与zip4j是不能相互解压的,原因还不清楚,请大神说说; 。
下面先看压缩文件夹: (author:余绍阳,qq:279907389) 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
|
//压缩单个文件
@Test
public
void
dozip1()
throws
ZipException {
ZipFile zip=
new
ZipFile(
"D://压缩//test.zip"
);
//需要判断压缩父路径是否存在
File file=zip.getFile();
if
(!file.getParentFile().exists()) {
file.getParentFile().mkdirs();
}
//设置参数
ZipParameters para=
new
ZipParameters();
//设置压缩方式,默认是COMP_DEFLATE
para.setCompressionMethod(Zip4jConstants.COMP_DEFLATE);
//设置压缩级别,默认为0(即不压缩)
para.setCompressionLevel(Zip4jConstants.DEFLATE_LEVEL_NORMAL);
//设置压缩密码(至少3步)
//设置加密文件
para.setEncryptFiles(
true
);
//设置加密方式(必须要有加密算法)
para.setEncryptionMethod(Zip4jConstants.ENC_METHOD_STANDARD);
para.setPassword(
"test111"
);
File srcFile=
new
File(
"src//com//学习路线.png"
);
zip.addFile(srcFile, para);
System.out.println(
"压缩成功!"
);
}
//压缩多个文件
@Test
public
void
dozip2()
throws
ZipException {
ZipFile zip=
new
ZipFile(
"D://压缩//test.zip"
);
//要紧跟设置编码
zip.setFileNameCharset(
"GBK"
);
ArrayList<File> list=
new
ArrayList<>();
list.add(
new
File(
"src//com//压缩解压//abc.txt"
));
list.add(
new
File(
"src//com//压缩解压//abcUTF-8.txt"
));
list.add(
new
File(
"src//com//压缩解压//解压之后.txt"
));
ZipParameters para=
new
ZipParameters();
para.setCompressionMethod(Zip4jConstants.COMP_DEFLATE);
para.setCompressionLevel(Zip4jConstants.DEFLATE_LEVEL_NORMAL);
//设置密码:
para.setEncryptFiles(
true
);
//设置AES加密方式
para.setEncryptionMethod(Zip4jConstants.ENC_METHOD_AES);
//必须设置长度
para.setAesKeyStrength(Zip4jConstants.AES_STRENGTH_256);
para.setPassword(
"111"
);
zip.addFiles(list, para);
System.out.println(
"压缩成功!"
);
}
//压缩文件夹
@Test
public
void
dozip3()
throws
ZipException {
ZipFile zip=
new
ZipFile(
"D:\\压缩\\test.zip"
);
File file=zip.getFile();
if
(!file.getParentFile().exists()) {
file.getParentFile().mkdirs();
}
//为了不被原有文件干扰,保证每次重新生成
if
(file.exists()) {
file.delete();
}
ZipParameters para=
new
ZipParameters();
//设置压缩级别,压缩方法默认
para.setCompressionLevel(Zip4jConstants.DEFLATE_LEVEL_NORMAL);
zip.addFolder(
"E:\\测试压缩"
, para);
System.out.println(
"压缩完成!"
);
|
解压 。
1.如果是用软件压缩(GBK)的,用zip4j解压时需要设置”GBK” 。
注意设置要紧接ZipFile设置,否则编码设置会失效,
1
2
|
ZipFile zipFile =
new
ZipFile(“D:\压缩\test.zip”);
zip.setFileNameCharset(“GBK”);
|
另外:在解压之后,如果再次解压,如果有新的文件会添加进去,相同的文件会覆盖;不同编码格式的会保留; 。
2.zip4j是支持中文密码的,但是如果是好压或者winRAR压缩并且设置中文密码,则使用zip4j解压会提示密码错误; 也就是说,用好压设置中文密码,只能用好压或者winRAR等软件解压;而使用zip4j设置的中文密码,好压或winRAR也不能解压,只能用自带的zip4j解压; 原因不清 。
3.密码2种设置方式:
a.para.setEncryptFiles(true),
1
2
3
|
//没有使用AES,那么就不需要AesKeyStrength
para.setEncryptionMethod(Zip4jConstants.ENC_METHOD_STANDARD)
para.setPassword(“
111
”);
|
b.para.setEncryptFiles(true),
1
2
3
4
|
para.setEncryptionMethod(Zip4jConstants.ENC_METHOD_AES);
//如果设置AES加密,那么必须指定AesKeyStrength
parameters.setAesKeyStrength(Zip4jConstants.AES_STRENGTH_256);
para.setPassword(“
111
”);
|
c.如果para.setEncryptFiles(false);那么密码将会失效 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
|
// 解压方法1
public
void
Unzip4j(String zipFile)
throws
ZipException {
long
startTime = System.currentTimeMillis();
//第一时间设置编码格式
zip.setFileNameCharset(
"GBK"
);
//用自带的方法检测一下zip文件是否合法,包括文件是否存在、是否为zip文件、是否被损坏等
if
(!zip.isValidZipFile()) {
throw
new
ZipException(
"文件不合法或不存在"
);
}
checkEncrypted(zip);
// 跟java自带相比,这里文件路径会自动生成,不用判断
zip.extractAll(
"D:\\压缩\\test1"
);
System.out.println(
"解压成功!"
);
long
endTime = System.currentTimeMillis();
System.out.println(
"耗时:"
+ (endTime - startTime) +
"ms"
);
}
// 解压方法2
public
void
Unzip4j1(String zipFile)
throws
ZipException {
long
startTime = System.currentTimeMillis();
ZipFile zipFile2 =
new
ZipFile(zipFile);
//设置编码格式
zipFile2.setFileNameCharset(
"GBK"
);
if
(!zipFile2.isValidZipFile()) {
throw
new
ZipException(
"文件不合法或不存在"
);
}
//检查是否需要密码
checkEncrypted(zipFile2);
List<FileHeader> fileHeaderList = zipFile2.getFileHeaders();
for
(
int
i =
0
; i < fileHeaderList.size(); i++) {
FileHeader fileHeader = fileHeaderList.get(i);
zipFile2.extractFile(fileHeader,
"D:\\压缩\\test"
);
}
System.out.println(
"解压成功!"
);
long
endTime = System.currentTimeMillis();
System.out.println(
"耗时:"
+ (endTime - startTime) +
"ms"
);
}
//检测密码
private
void
checkEncrypted(ZipFile zip)
throws
ZipException {
Scanner in=
new
Scanner(System.in);
if
(zip.isEncrypted()) {
System.out.println(
"文件"
+zip.getFile().getName()+
"有密码!"
);
System.out.println(
"请输入密码:"
);
zip.setPassword(in.next().trim());
}
in.close();
}
|
其他功能 。
1.添加:是往zip文件添加非zip文件 。
在添加文件时,发现只能添加一次,再次添加报错:Expected central directory entry not found (#1),原因还不知道,55 另外,如果要添加的zip文件不存在,那么将会创建一个zip文件,再添加文件;如果要添加的a.txt文件不存在,则报错”没有找到文件” 。
2.分卷:是压缩的时候进行,可针对带个文件或者文件夹 ,分卷后每份压缩文件大小至少64k(65536byte) 如果在对文件(文件夹)分卷压缩前,其已经压缩了,那么将会分卷报错! 那么如何解压呢?对任意一个分卷压缩文件解压即可全部解压; 。
3.预览压缩文件信息 。
4.删除功能在下一篇展示,这个在zip文件删除指定文件夹有一种非常巧妙的方法(非常规思路),不需要递归; 。
代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
public
static
void
addFile(String srczipFile, String addfile)
throws
Exception {
ZipFile zip =
new
ZipFile(srczipFile);
ZipParameters para =
new
ZipParameters();
// 封装待添加文件
FileInputStream fis =
new
FileInputStream(addfile);
String fileName =
new
File(addfile).getName();
System.out.println(fileName);
// 这里可以设置文件夹,会自动在压缩文件中创建这些文件夹
// String Folder="1\\2\\";
// para.setFileNameInZip(Folder+fileName);
para.setFileNameInZip(fileName);
// 资源扩展
para.setSourceExternalStream(
true
);
// 添加文件
zip.addStream(fis, para);
fis.close();
System.out.println(
"添加成功!"
);
}
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
// 分卷,将几个文件进行分卷压缩,一个单位64k
public
static
void
zipTOSplit(String destZipFile,
int
unit)
throws
ZipException {
ZipFile zip =
new
ZipFile(destZipFile);
ArrayList<File> list =
new
ArrayList<File>();
list.add(
new
File(
"src//com//压缩解压//abc.txt"
));
list.add(
new
File(
"src//com//压缩解压//abcUTF-8.txt"
));
list.add(
new
File(
"src//com//cbzk//压缩解压//解压之后.txt"
));
ZipParameters para =
new
ZipParameters();
para.setCompressionLevel(Zip4jConstants.DEFLATE_LEVEL_FAST);
// 创建分卷
zip.createZipFile(list, para,
true
, unit *
65536
);
System.out.println(
"分卷成功!"
);
}
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
|
// 将文件夹进行分卷压缩
public
static
void
zipTOSplit(String destZipFile, String srcFolder,
int
unit)
throws
ZipException {
ZipFile zip =
new
ZipFile(destZipFile);
ZipParameters para =
new
ZipParameters();
// 默认COMP_DEFLATE
para.setCompressionMethod(Zip4jConstants.COMP_DEFLATE);
para.setCompressionLevel(Zip4jConstants.DEFLATE_LEVEL_NORMAL);
// 分卷压缩文件夹到指定压缩位置
zip.createZipFileFromFolder(srcFolder, para,
true
, unit *
65536
);
//粗略的算一下分成多少份,获取的大小比实际的大点(一般是准确的)
int
partsize=(
int
)zipInfo(destZipFile)/(unit*
64
);
//65536byte=64kb
System.out.println(
"分割成功!总共分割成了"
+(partsize+
1
)+
"个文件!"
);
}
// 预览压缩文件信息
public
static
double
zipInfo(String zipFile)
throws
ZipException {
ZipFile zip =
new
ZipFile(zipFile);
zip.setFileNameCharset(
"GBK"
);
List<FileHeader> list = zip.getFileHeaders();
long
zipCompressedSize=
0
;
for
(FileHeader head:list){
zipCompressedSize+=head.getCompressedSize();
// System.out.println(zipFile+"文件相关信息如下:");
// System.out.println("Name: "+head.getFileName());
// System.out.println("Compressed Size:"+(head.getCompressedSize()/1.0/1024)+"kb");
// System.out.println("Uncompressed Size:"+(head.getUncompressedSize()/1.0/1024)+"kb");
// System.out.println("CRC32:"+head.getCrc32());
// System.out.println("*************************************");
}
double
size=zipCompressedSize/
1.0
/
1024
;
//转换为kb
return
size;
}
|
如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持! 。
原文链接:http://blog.csdn.net/u011165335/article/details/50496930 。
最后此篇关于ZIP4j 压缩与解压的实例详解的文章就讲到这里了,如果你想了解更多关于ZIP4j 压缩与解压的实例详解的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我有点想做 the reverse of this. 我不想解压缩并将收集文件添加到 S3 应用户要求: 生成一堆xml文件 使用一些图像(托管在 s3 上的预先存在的图像)压缩 xml 文件 下载
将此添加到域的虚拟主机后 AddOutputFilterByType DEFLATE application/javascript text/javascript text/css 响应头不包含任何内
在 Apache Im 中,通过将以下内容添加到我的 .htaccess 文件来启用输出压缩: # compress text, html, javascript, css, xml: AddOutp
是否可以以压缩格式将请求数据从浏览器发送到服务器? 如果是,我们该怎么做? 最佳答案 压缩从浏览器发送到服务器的数据是不受 native 支持 在浏览器中。 您必须找到一种解决方法,使用客户端语言(可
我正在寻找可以压缩JavaScript源代码的工具。我发现一些网络工具只能删除空格字符?但也许存在更好的工具,可以压缩用户的函数名称、字段名称、删除未使用的字段等。 最佳答案 经常用来压缩JS代码的工
使用赛马博彩场景,假设我有许多单独的投注来预测比赛的前 4 名选手 (superfecta)。 赌注如下... 1/2/3/4 1/2/3/5 1/2/4/3 1/2/4/5 1/2/5/3
我是一名实习生,被要求对 SQL 2008 数据压缩进行一些研究。我们想将 Outlook 电子邮件的几个部分存储在一个表中。问题是我们想将整个电子邮件正文存储在一个字段中,然后又想压缩它。使用 Ch
我目前有一个系统,用户可以在其中上传 MP4 文件,并且可以在移动设备上下载该文件。但有时,这些视频的大小超过 5MB,在我国,大多数人使用 2G。因此,下载大型视频通常需要 15-20 分钟。 有什
假设我有一个带有类型列的简单文档表: Documents Id Type 1 A 2 A 3 B 4 C 5 C 6 A 7 A 8 A 9 B 10 C 用户
我有一个较大字符串中的(子)字符串位置的 data.frame。数据包含(子)字符串的开头及其长度。可以很容易地计算出(子)字符串的结束位置。 data1 start length end #>
我想知道是否 文件加密算法可以设计成它也可以执行文件压缩的事件(任何活生生的例子?)。 我也可以将它集成到移动短信服务中,我的意思是短信吗? 另外我想知道二进制文件...如果纯文本文件以二进制编码
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 7年前关闭。 Improve thi
我们有几个具有大量 JavaScript 的 Java 项目,目前我们使用的是旧版本的 YUICompressor (2.4.2)。然而,我在这篇博文中发现 YUICompressor 正在 depr
从之前关于尝试提高网站性能的文章中,我一直在研究 HTTP 压缩。我读过有关在 IIS 中设置它的信息,但它似乎是所有 IIS 应用程序池的全局事物,我可能不允许这样做,因为还有另一个站点在其上运行。
我有一个 REST 服务,它返回一大块 XML,大约值(value) 150k。 例如http://xmlservice.com/services/RestService.svc/GetLargeXM
我正在尝试获取一个简单的 UglifyJS (v2.3.6) 示例来处理压缩。 具体来说,“未使用”选项,如果从未使用过,变量和函数将被删除。 这是我在命令行上的尝试: echo "function
我正在开发一个项目,如果我的磁盘出现问题,我将在使用 ZLIB 压缩内存块后将其发送到另一个磁盘。然后我计划下载该转储并用于进一步调试。这种压缩和上传将一次完成一个 block - 比如说 1024
LZW 压缩算法在压缩后增加了位大小: 这是压缩函数的代码: // compression void compress(FILE *inputFile, FILE *outputFile) {
我的问题与如何在 3D 地形上存储大量信息有关。这些信息应该是 secret 的,因为它们非常庞大,也应该被压缩。我选择了文件存储,现在我想知道将对象数据加密/压缩(或压缩/加密)到文件的最佳做法。
我使用以下代码来压缩我的文件并且效果很好,但我只想压缩子文件夹而不是在压缩文件中显示树的根。 public boolean zipFileAtPath(String sourcePath, Strin
我是一名优秀的程序员,十分优秀!