如何打JAR包,可执行的JAR包

//压缩文件目录

通常回答只有两种,一种是制作一个可执行的 JAR 文件包,然后就可以像.chm 文档一样双击运行了;而另一种是使用 JET 来进行 编译。但是

jar包解压_jar包解压缩jar包解压_jar包解压缩


jar包解压_jar包解压缩


文件包的方法就是选择了,何况它还能保持 Ja 的跨平台特性。

下面就来看看什么是 JAR 文件包吧:

1. JAR 文件包

文件就是 Ja Archive File,顾名思意,它的应用是与 Ja 息息相关的,是 Ja 的一种文档格式。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 文件包最典型的用法。

Ja

程序是由若干个 .class 文件组成的。这些 .class

文件必须根据它们所属的包不同而分级分目录存放;运行前需要把所有用到的包的根目录指定给 CLASSPATH 环境变量或者 ja 命令的 -cp

参数;运行时还要到控制台下去使用 ja 命令来运行,如果需要直接双击运行必须写 Windows 的批处理文件 (.bat) 或者

其实不然,如果开发者能

够制作一个可执行的 JAR 文件包交给用户,那么用户使用起来就方便了。在 Windows 下安装 JRE (Ja Runtime

Environment) 的时候,安装文件会将 .jar 文件映射给 jaw.exe 打开。那么,对于一个可执行的 JAR

文件包,用户只需要双击它就可以运行程序了,和阅读 .chm 文档一样方便 (.chm 文档默认是由 hh.exe

打开的)。那么,现在的关键,就是如何来创建这个可执行的 JAR 文件包。

创建可执行的 JAR 文件包,需要使用带 cvfm 参数的 jar 命令,同样以上述 test 目录为例,命令如下:

jar cvfm test.jar manifest.mf test

这里 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 包的,而且是可执行的类 (定义了 public static void main(String[]) 方法),那么这个 manifest.mf 可以编辑如下:

Main-Class: test.Test <回车>;

这个 manifest.mf 可以放在任何位置,也可以是其它的文件名,只需要有 Main-Class: test.Test 一行,且该行以一个回车符结束即可。创建了 manifest.mf 文件之后,我们的目录结构变为:

|-- test

| `-- Test.class

`-- mani| `-- MANIFESTfest.mf

这时候,需要到 test 目录的上级目录中去使用 jar 命令来创建 JAR 文件包。也就是在目录树中使用“==”表示的那个目录中,使用如下命令:

jar cvfm test.jar manifest.mf test

之后在“==”目录中创建了 test.jar,这个 test.jar 就是执行的 JAR 文件包。运行时只需要使用 ja -jar test.jar 命令即可。

需要注意的是,创建的 JAR 文件包中需要包含完整的、与 Ja 程序的包结构对应的目录结构,就像上例一样。而 Main-Class

指定的类,也必须是完整的、包含包路径的类名,如上例的 test.Test;而且在没有打成 JAR 文件包之前可以使用 ja

<类名>; 来运行这个类,即在上例中 ja test.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 中的一个,它们分别表示:

-t列出 JAR 文件包的内容列表

-x展开 JAR 文件包的指定文件或者所有文件

-u更新已存在的 JAR 文件包 (添加文件到 JAR 文件包中)

[vfm0M] 中的选项可以任选,也可以不选,它们是 jar 命令的选项参数

-v生成详细报告并打印到标准输出

-f指定 JAR 文件名,通常这个参数是必须的

-m指定需要包含的 MANIFEST 清单文件

[jar-文件] 即需要生成、查看、更新或者解开的 JAR 文件包,它是 -f 参数的附属参数

[manifest-文件] 即 MANIFEST 清单文件,它是 -m 参数的附属参数

文件名 ... 指定一个文件/目录列表,这些文件/目录就是要添加到 JAR 文件包中的文件/目录。如果指定了目录,那么 jar 命令打包的时候会自动把该目录中的所有文件和子目录打入包中。

下面举一些例子来说明 jar 命令的用法:

1) jar cf test.jar test

该命令没有执行过程的显示,执行结果是在当前目录生成了 test.jar 文件。如果当前目录已经存在 test.jar,那么该文件将被覆盖。

2) jar cvf test.jar test

该命令与上例中的结果相同,但是由于 v 参数的作用,显示出了打包过程,如下:

标明清单(manifest)

增加:test/(读入= 0) (写出= 0)(存储了 0%)

增加:test/Test.class(读入= 7) (写出= 6)(压缩了 14%)

3) jar cvfM test.jar test

该命令与 2) 结果类似,但在生成的 test.jar 中没有包含 META-INF/MANIFEST 文件,打包过程的信息也略有别:

增加:test/(读入= 0) (写出= 0)(存储了 0%)

增加:test/Test.class(读入= 7) (写出= 6)(压缩了 14%)

4) jar cvfm test.jar manifest.mf test

运行结果与 2) 相似,显示信息也相同,只是生成 JAR 包中的 META-INF/MANIFEST 内容不同,是包含了 manifest.mf 的内容

5) jar tf test.jar

对于 2)

META-INF/

META-INF/MANIFEST.MF

test/

test/Test.class

对于 3)

test/

test/Test.class

6) jar tvf test.jar

除显示 5) 中显示的内容外,还包括包内文件的详细信息,如:

0 Wed Jun 19 15:39:06 GMT 2002 META-INF/

86 Wed Jun 19 15:39:06 GMT 2002 META-INF/MANIFEST.MF

0 Wed Jun 19 15:33:04 GMT 2002 test/

7 Wed Jun 19 15:33:04 GMT 2002 test/Test.class

解开 test.jar 到当前目录,不显示任何信息,对于 2) 生成的 test.jar,解开后的目录结构如下:

|-- META-INF

`-- test

`--Test.class

8) jar xvf test.jar

运行结果与 7) 相同,对于解压过程有详细信息显示,如:

创建:META-INF/

展开:META-INF/MANIFEST.MF

创建:test/

展开:test/Test.class

9) jar uf test.jar manifest.mf

在test.jar 中添加了文件 manifest.mf,此使用 jar tf 来查看 test.jar 可以发现 test.jar

中比原来多了一个 manifest。这里顺便提一下,如果使用 -m 参数并指定 manifest.mf 文件,那么 manifest.mf

是作为清单文件 MANIFEST 来使用的,它的内容会被添加到 MANIFEST 中;但是,如果作为一般文件添加到 JAR

文件包中,它跟一般文件无异。

10) jar uvf test.jar manifest.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 参数即可。如:

unzip test.jar -d dest/

上面提到 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) 个例子略作改动:

jar cvfM test.zip test

ja线上部署直接用jar包还是解压缩

Linux 的 Shell 程序。因此,许多人说,Ja 是一种方便开发者苦了用户的程序设计语言。

jar包。Ja线上部署项目通常要打包成jar包才能上线。在软件领域,JAR文件是一种软件包文件格式,通常用于聚合大量的Ja类文件、相关的元数据和资源(文本、等)文件到一个文件,以便开发Ja平台应用软件或库。

==

WIN7下怎么修复JAR文件的打开方式?

(2)更改excludelib/build.gradle

Win7下修复软文建的打开方式,这个如果不能打开的话,应该建议a锁坏再次安装就可以正确打开。

String filepath =childFile.getAbsolutePath()+File.separator;

你要安装ja的环境包才可以。要把框架程序安装上去才可以运行。

如何将文件夹压缩成JAR文件

7) jar xf test.jar

先解压,然后压缩为zip,然后将后缀名改为jar。

e.printStackTrace();

本ja小工具是可实现批量压缩文件包为jar包,核心代码如下:

/

zip压缩

@param parentDirPath 要压缩文件夹的父文件夹

@param targetPath 目标文件夹

/

private static void zipDirectory(String parentDirPath,String targetPath)

{try {

File dirFile=new File(parentDirPath);

File[] listArr = dirFile.listFiles();

//File childFile=new File(child);

if(childFile.isDirectory())

{if(list.size()>0)

list.clear();

byte b[] = new byte[128];

//压缩文件的保存路径

String zipFile =targetPath+File.separator+childFile.getName()+".jar";

List fileList = allFile(filepath);

FileOutputStream fileOutputStream = new FileOutputStream(zipFile);

//使用输出流检查

CheckedOutputStream cs = new CheckedOutputStream(fileOutputStream, new CRC32());

//声明输出zip流

ZipOutputStream out = new ZipOutputStream(new BufferedOutputStream(

cs));

for (int i = 0; i < fileList.size(); i++) {

InputStream in = new FileInputStream((String)fileList.get(i));

System.out.println("ziping " + fileName);

String tmp= childFile.getName()+"/";

fileName = fileName.substring(fileName.lastIndexOf(tmp)+childFile.getName().length()+1);

ZipEntry e = new ZipEntry(fileName);

out.putNextEntry(e);

int len = 0;

while((len = in.read(b)) != -1) {

out.write(b,0,len);

}out.closeEntry();

}out.close();

System.out.println("done!");

}}

} catch (Exception e) {

}}

ja 如何打开一个jar包

-c创建新的 JAR 文件包

用MyEclipse工具 左侧的项目列表 添加jar包就可以了。

jar包的东西一般都是编译过的.class文件,如果要做二次开发,就要进行反编译,将文件反编译成.ja文件。eclipse反编译我没用过,不知道效果怎么样。

...一般的解压缩工具就可-0只存储,不压缩,这样产生的 JAR 文件包会比不用该参数产生的体积大,但速度更快以啊

jar文件运行不了怎么办?

JET 是要用钱买的,而且据说 JET 也不是能把所有的 Ja 程序都编译成执行文件,性能也要打些折扣。所以,使用制作可执行 JAR

可能jar文件损坏了,你可以尝试用winrar打开这个jar文件,把它解压,看有没有报错,如果报错,说明文件损坏了。

打包成jar文件后运行出现Invalid or corrupt jarfile 解决打jar包

1。jar -cvf hello。jar hello。class

2。这时ja -jar hello。jar 是运行不了的

3。解压刚打的Jar包到新的目录,会发现里边多了一个META-INF文件夹里边有一个MANIFEST。MF文件

4。用记事本打开MANIFEST。MF文件,修改为

Manifest-Version: 1。0

Main-Class: Hello

Created-By:

5。将MANIFEST。MF到和Hello。class 放在一起

然后打for (File childFile : listArr) {包:

jar cvfm abc。jarMANIFEST。MFHello。class

得到可运行的jar

ja -jar 就可以运行的jar包[ 其中为jar包名]

jar压缩文件解压后怎么都是class文件

JAR

jar包就是class文件打成的 打开了当然就全是class了 你直接运行jar包就行 解压它干嘛

[-C 目录] 表示转到指定目录下去执行这个 jar 命令的作。它相当于先使用 cd 命令转该目录下再执行不带 -C 参数的 jar 命令,它只能在创建和更新 JAR 文件包的时候可用。

当然了

不需要解压的

你只要把jar文件正确的放入你的文件夹 记住 是正确的文件夹 不然不行

然后进入那个文件夹 就可以直接使用了

我的机子就是先安装后使用的

jar是已经打好包的文件了 不用解压 直接放就可以

排除aar/jar中冗余或者冲突包、类

2) 使用 WinZip 或者 WinRAR 等工具创建 JAR 文件

引入aar的冲突无所不在,通过远程依赖men的包可以通过 exclude 关键字搭配 module 和 group 去除某个组,没办法去除具体的类。

4、按照排除规则对解压的class.jar重新打包(Task Jar)

那么如果是单独的aar包,想要排除aar下classes.jar包里的某个单独的包或者类怎么办?

需要接入的jar包已经带了腾讯X5核心,当前依赖的已经包含X5核心,冲突又该如何解决呢?

当前的gradle脚本(项目链接: )可以解决。

如excludelib/libs/exampleAAR.aar,左边是未去除的包结构,右边是去除 com.baidu 之后的:

如excludelib/libs/exampleJAR.jar:

(1)将需要排除的aar或者jar包放在excludelib/libs下。

(3)设置排除规则 如果您需要排除aar,那么请更改excludelib/excludeAar.gradle;如果您需要排除jar,那么请更改excludelib/excludeJar.gradle

(4)运行排除任务

排除后生成的aar在excludelib/build/excludeaar下,排除后生成的jar位于excludelib/build/excludejar。

然后就可以愉快的使用啦~

aar排除步骤:

1、获取到需要排除的原始AAR包

3、解压AAR包中的class.jar(zipTree配合Task Copy)

5、重新打包成AAR包(Task Zip)

jar排除步骤

1、获取到需要排除的原始jar包

2、解压jar包(zipTree配合Task Copy)

3、按照排除规则对解压的jar重新打包(Task Jar)

主要原理:zipTree配合Copy,实现解压。

Copy Task讲解:

ziptree源码主要解析:创建一个新的file tree包含原来zip的内容,可以配合Copy实现解压。

Task Jar讲解:

对classes.jar处理完成的aar重打包,主要用到Task Zip。

Task Zip讲解:

感谢Siy:

怎么修改jar包中的class文件然后再重新打成jar包

在 test.jar 已经存在的情况下,可以查看 test.jar 中的内容,如对于 2) 和 3) 生成的 test.jar 分别应该此命令,结果如下;

该过程需要经历四个步骤:解压,反编译,修改,打包。

解压:jar文件和我们平常的rar和zip文件一样是属于压缩文件,通过一般的解压缩工具(例如:winrar)都能解压。解压之后生成的文件为.class的字节码文件。

反编译:互联网上有很多的字节码文件反编译工具(例如:jad)。他能够将.class文件或者直接能够将jar文件反编译为.ja文2、解压AAR包(zipTree配合Task Copy)件。

得到ja文件以后就可以修改里面的源代码了。

将修改好的代码编译成.class字节码文件以后再添加替换掉原来jar包中的class文件,或者重新将修改后的ja代码转换成ja工程,再生成jar文件都行。

这个过程的完成需要熟悉ja基础,编译环境等相关知识。尤其是对jar包的理解很重要。反编译在互连网上就能直接找到很多工具。打包则很简单不做累述。