java打包命令
用法: jar {ctxui}[vfmn0PMe] [jar-file] [manifest-file] [entry-point] [-Cdir] files ...
选项:
-c 创建新档案
-t 列出档案目录
-x 从档案中提取指定的 (或所有) 文件
-u 更新现有档案
-v 在标准输出中生成详细输出
-f 指定档案文件名
-m 包含指定清单文件中的清单信息
-n 创建新档案后执行 Pack200 规范化
-e 为捆绑到可执行 jar 文件的独立应用程序
指定应用程序入口点
-0 仅存储; 不使用任何 ZIP 压缩
-P 保留文件名中的前导 '/' (绝对路径) 和 ".." (父目录) 组件
-M 不创建条目的清单文件
-i 为指定的 jar 文件生成索引信息
-C 更改为指定的目录并包含以下文件
如果任何文件为目录, 则对其进行递归处理。
清单文件名, 档案文件名和入口点名称的指定顺序
与 'm', 'f' 和 'e' 标记的指定顺序相同。
示例 1: 将两个类文件归档到一个名为 classes.jar 的档案中:
jar cvf classes.jar Foo.class Bar.class
示例 2: 使用现有的清单文件 'mymanifest' 并
将 foo/ 目录中的所有文件归档到 'classes.jar' 中:
jar cvfm classes.jar mymanifest -C foo/ .
指定class文件时必须依照源代码里包名结构,例,包名结构为com\**\**
要产生能运行的jar文件需采用实例2所示的指令,手动添加manifest文件
【jar】【cvfm】【想要的包文件名】【manifest】【-C】【目录1】【目录2】【目录3】...
MANIFEST.MF只需要指定位置即可,不需要专门放在打包目录
由于-C含义,指令会进入到目录一下,将目录2目录3...的内容(在目录1下)(若是class文件就要指定到com)打包在一起
打包的class文件结构要和源代码里包文件名一致
例: jar -cvmf MANIFEST.MF pack.jar com
jar [cvmf] [MANIFEST.MF] [想要的包文件名] [将要包起来的文件]
在这条指令中只有一个指定文件夹,包含素材和class文件都在这个文件夹中
本命令不会进入到指定文件夹,所以在指定class文件时只能指定到com
需要在源文件中加入package信息
MANIFEST.MF文件格式:
Manifast-version:1.0
Main-class:文件路径
执行jar:
java -jar jar文件名.jar