制作可执行的JAR文件包及jar命令详解.docx
《制作可执行的JAR文件包及jar命令详解.docx》由会员分享,可在线阅读,更多相关《制作可执行的JAR文件包及jar命令详解.docx(9页珍藏版)》请在冰点文库上搜索。
制作可执行的JAR文件包及jar命令详解
制作可执行的JAR文件包及jar命令详解
1.JAR文件包
JAR文件确实是JavaArchiveFile,顾名思意,它的应用是与Java息息有关的,是Java的一种文档格式。
JAR文件专门类似ZIP文件——准确的讲,它确实是ZIP文件,因此叫它文件包。
JAR文件与ZIP文件唯独的区别确实是在JAR文件的内容中,包含了一个META-INF/MANIFEST.MF文件,那个文件是在生成JAR文件的时候自动创建的。
举个例子,如果我们具有如下名目结构的一些文件:
==
`--test
`--Test.class
把它压缩成ZIP文件test.zip,则那个ZIP文件的内部名目结构为:
test.zip
`--test
`--Test.class
如果我们使用JDK的jar命令把它打成JAR文件包test.jar,则那个JAR文件的内部名目结构为:
test.jar
|--META-INF
| `--MANIFEST.MF
`--test
`--Test.class
2.创建可执行的JAR文件包
制作一个可执行的JAR文件包来公布你的程序是JAR文件包最典型的用法。
Java程序是由若干个.class文件组成的。
这些.class文件必须按照它们所属的包不同而分级分名目存放;运行前需要把所有用到的包的根名目指定给CLASSPATH环境变量或者java命令的-cp参数;运行时还要到操纵台下去使用java命令来运行,如果需要直截了当双击运行必须写Windows的批处理文件(.bat)或者Linux的Shell程序。
因此,许多人讲,Java是一种方便开发者苦了用户的程序设计语言。
事实上不然,如果开发者能够制作一个可执行的JAR文件包交给用户,那么用户使用起来就方便了。
在Windows下安装JRE(JavaRuntimeEnvironment)的时候,安装文件会将.jar文件映射给javaw.exe打开。
那么,关于一个可执行的JAR文件包,用户只需要双击它就能够运行程序了,和阅读.chm文档一样方便(.chm文档默认是由hh.exe打开的)。
那么,现在的关键,确实是如何来创建那个可执行的JAR文件包。
创建可执行的JAR文件包,需要使用带cvfm参数的jar命令,同样以上述test名目为例,命令如下:
jarcvfmtest.jarmanifest.mftest
那个地点test.jar和manifest.mf两个文件,分别是对应的参数f和m,其重头戏在manifest.mf。
因为要创建可执行的JAR文件包,光靠指定一个manifest.mf文件是不够的,因为MANIFEST是JAR文件包的特点,可执行的JAR文件包和不可执行的JAR文件包都包含MANIFEST。
关键在于可执行JAR文件包的MANIFEST,其内容包含了Main-Class一项。
这在MANIFEST中书写格式如下:
Main-Class:
可执行主类全名(包含包名)
例如,假设上例中的Test.class是属于test包的,而且是可执行的类(定义了publicstaticvoidmain(String[])方法),那么那个manifest.mf能够编辑如下:
Main-Class:
test.Test<回车>;
那个manifest.mf能够放在任何位置,也能够是其它的文件名,只需要有Main-Class:
test.Test一行,且该行以一个回车符终止即可。
创建了manifest.mf文件之后,我们的名目结构变为:
==
|--test
| `--Test.class
`--manifest.mf
这时候,需要到test名目的上级名目中去使用jar命令来创建JAR文件包。
也确实是在名目树中使用“==”表示的那个名目中,使用如下命令:
jarcvfmtest.jarmanifest.mftest
之后在“==”名目中创建了test.jar,那个test.jar确实是执行的JAR文件包。
运行时只需要使用java-jartest.jar命令即可。
需要注意的是,创建的JAR文件包中需要包含完整的、与Java程序的包结构对应的名目结构,就像上例一样。
而Main-Class指定的类,也必须是完整的、包含包路径的类名,如上例的test.Test;而且在没有打成JAR文件包之前能够使用java<类名>;来运行那个类,即在上例中javatest.Test是能够正确运行的(所以要在CLASSPATH正确的情形下)。
3.jar命令详解
jar是随JDK安装的,在JDK安装名目下的bin名目中,Windows下文件名为jar.exe,Linux下文件名为jar。
它的运行需要用到JDK安装名目下lib名目中的tools.jar文件。
只是我们除了安装JDK什么也不需要做,因为SUN差不多帮我们做好了。
我们甚至不需要将tools.jar放到CLASSPATH中。
使用不带任何的jar命令我们能够看到jar命令的用法如下:
jar{ctxu}[vfm0M][jar-文件][manifest-文件][-C名目]文件名...
其中{ctxu}是jar命令的子命令,每次jar命令只能包含ctxu中的一个,它们分别表示:
-c 创建新的JAR文件包
-t 列出JAR文件包的内容列表
-x 展开JAR文件包的指定文件或者所有文件
-u 更新已存在的JAR文件包(添加文件到JAR文件包中)
[vfm0M]中的选项能够任选,也能够不选,它们是jar命令的选项参数
-v 生成详细报告并打印到标准输出
-f 指定JAR文件名,通常那个参数是必须的
-m 指定需要包含的MANIFEST清单文件
-0 只储备,不压缩,如此产生的JAR文件包会比不用该参数产生的体积大,但速度更快
-M 不产生所有项的清单(MANIFEST〕文件,此参数会忽略-m参数
[jar-文件]即需要生成、查看、更新或者解开的JAR文件包,它是-f参数的附属参数
[manifest-文件]即MANIFEST清单文件,它是-m参数的附属参数
[-C名目]表示转到指定名目下去执行那个jar命令的操作。
它相当于先使用cd命令转该名目下再执行不带-C参数的jar命令,它只能在创建和更新JAR文件包的时候可用。
文件名...指定一个文件/名目列表,这些文件/名目确实是要添加到JAR文件包中的文件/名目。
如果指定了名目,那么jar命令打包的时候会自动把该名目中的所有文件和子名目打入包中。
下面举一些例子来讲明jar命令的用法:
1)jarcftest.jartest
该命令没有执行过程的显示,执行结果是在当前名目生成了test.jar文件。
如果当前名目差不多存在test.jar,那么该文件将被覆盖。
2)jarcvftest.jartest
该命令与上例中的结果相同,然而由于v参数的作用,显示出了打包过程,如下:
标明清单(manifest)
增加:
test/(读入=0)(写出=0)(储备了0%)
增加:
test/Test.class(读入=7)(写出=6)(压缩了14%)
3)jarcvfMtest.jartest
该命令与2)结果类似,但在生成的test.jar中没有包含META-INF/MANIFEST文件,打包过程的信息也略有差别:
增加:
test/(读入=0)(写出=0)(储备了0%)
增加:
test/Test.class(读入=7)(写出=6)(压缩了14%)
4)jarcvfmtest.jarmanifest.mftest
运行结果与2)相似,显示信息也相同,只是生成JAR包中的META-INF/MANIFEST内容不同,是包含了manifest.mf的内容
5)jartftest.jar
在test.jar差不多存在的情形下,能够查看test.jar中的内容,如关于2)和3)生成的test.jar分别应该此命令,结果如下;
关于2)
META-INF/
META-INF/MANIFEST.MF
test/
test/Test.class
关于3)
test/
test/Test.class
6)jartvftest.jar
除显示5)中显示的内容外,还包括包内文件的详细信息,如:
0WedJun1915:
39:
06GMT2002META-INF/
86WedJun1915:
39:
06GMT2002META-INF/MANIFEST.MF
0WedJun1915:
33:
04GMT2002test/
7WedJun1915:
33:
04GMT2002test/Test.class
7)jarxftest.jar
解开test.jar到当前名目,不显示任何信息,关于2)生成的test.jar,解开后的名目结构如下:
==
|--META-INF
| `--MANIFEST
`--test
`--Test.class
8)jarxvftest.jar
运行结果与7)相同,关于解压过程有详细信息显示,如:
创建:
META-INF/
展开:
META-INF/MANIFEST.MF
创建:
test/
展开:
test/Test.class
9)jaruftest.jarmanifest.mf
在test.jar中添加了文件manifest.mf,此使用jartf来查看test.jar能够发觉test.jar中比原先多了一个manifest。
那个地点顺便提一下,如果使用-m参数并指定manifest.mf文件,那么manifest.mf是作为清单文件MANIFEST来使用的,它的内容会被添加到MANIFEST中;然而,如果作为一样文件添加到JAR文件包中,它跟一样文件无异。
10)jaruvftest.jarmanifest.mf
与9)结果相同,同时有详细信息显示,如:
增加:
manifest.mf(读入=17)(写出=19)(压缩了-11%)
4.关于JAR文件包的一些技巧
1)使用unzip来解压JAR文件
在介绍JAR文件的时候就差不多讲过了,JAR文件实际上确实是ZIP文件,因此能够使用常见的一些解压ZIP文件的工具来解压JAR文件,如Windows下的WinZip、WinRAR等和Linux下的unzip等。
使用WinZip和WinRAR等来解压是因为它们解压比较直观,方便。
而使用unzip,则是因为它解压时能够使用-d参数指定目标名目。
在解压一个JAR文件的时候是不能使用jar的-C参数来指定解压的目标的,因为-C参数只在创建或者更新包的时候可用。
那么需要将文件解压到某个指定名目下的时候就需要先将这具JAR文件拷贝到目标名目下,再进行解压,比较苦恼。
如果使用unzip,就不需要这么苦恼了,只需要指定一个-d参数即可。
如:
unziptest.jar-ddest/
2)使用WinZip或者WinRAR等工具创建JAR文件
上面提到JAR文件确实是包含了META-INF/MANIFEST的ZIP文件,因此,只需要使用WinZip、WinRAR等工具创建所需要ZIP压缩包,再往那个ZIP压缩包中添加一个包含MANIFEST文件的META-INF名目即可。
关于使用jar命令的-m参数指定清单文件的情形,只需要将那个MANIFEST按需要修改即可。
3)使用jar命令创建ZIP文件
有些Linux下提供了unzip命令,但没有zip命令,因此需要能够对ZIP文件进行解压,即不能创建ZIP文件。
如要创建一个ZIP文件,使用带-M参数的jar命令即可,因为-M参数表示制作JAR包的时候不添加MANIFEST清单,那么只需要在指定目标JAR文件的地点将.jar扩展名改为.zip扩展名,创建的确实是一个不折不扣的ZIP文件了,如将上一节的第3)个例子略作改动:
jarcvfMtest.ziptest