1)若生成的jar包直接导入java工程中使用,可以不用MANIFEST.MF文件,直接在工程中导入jar包引用到的第三方包;
2)若生成的jar包需要放到服务器上跑,在jar包的存放路径下同时存放一个lib文件夹,在该文件夹中存放第三方包,如图所示:
再在MANIFEST.MF文件中指定第三方包的位置,MANIFEST.MF中内容如下:
Manifest-Version: 1.0
Class-Path: lib/ansj_seg-5.0.2-all-in-one.jar lib/args4j-2.0.6.jar
lib/glpk-java.jar lib/hanlp-1.3.4.jar lib/ik-analyzer-solr5-5.x.jar
lib/javailp-1.2a.jar lib/jgibblda.jar lib/poi-3.15.jar lib/weka.jar
Main-Class: edu.ecnu.dase.sm.SMTester
第一行是MAINIFEST的版本,第二行Class-Path就指定了外来jar包的位置,第三行指定我们要执行的MAIN java文件。
这里要注意几点:
复制代码
1、Class-Path: 和Main-Class: 后边都有一个空格,必须加上,否则会打包失败,错误提示为:Invalid header field;
2、假设我们的项目打包后为SumECNU4.0.jar,那么按照上面的定义,应该在 SumECNU4.0.jar的同层目录下建立一个lib文件夹(即lib文件和打包的jar文件在同一个目录下),并将相关的jar包放在里面。否则将会出现“Exception in thread “main” java.lang.NoClassDefFoundError”的错误;
3、Main-Class后面是类的全地址,比如你的主文件是SMTester.java,文件里打包为package edu.ecnu.dase.test; 那么这里就写edu.ecnu.dase.test.SMTester,不要加.java后缀,主文件地址写错将会出现“找不到或无法加载主类”的错误;
4、写完Main-Class后一定要回车(即最后一行是空白行),让光标到下一行,这样你生成的jar包才能找到你的主class去运行,否则将会出现“jar中没有主清单属性”的错误。
第一次打包的时候,将data、models、doc文件夹和stop_words_ch.txt文件都添加进去了,生成的jar包178M,后来发现在引用这个jar包的工程中还是需要导入这些文件,否则代码报错,说明这些文件打包在jar中并不能起到作用。
第二次打包就只添加了src进去,生成jar包只有159k,可以说是专业点的jar包了。
其中有几个选项的含义:
Export generated class files and resources 表示只导出生成的.class文件和其他资源文件
Export all output folders for checked projects 表示导出选中项目的所有文件夹
Export java source file and resouces 表示导出的jar包中将包含你的源代码*.java,如果你不想泄漏源代码,那么就不要选这项了
Export refactorings for checked projects 把一些重构的信息文件也包含进去
1) 若是1. 中的1) 情况,直接选择默认选项就好。
2)若是1. 中的2)情况,则一定不能默认选项,选择第一步自定义配置文件MANIFEST.MF的路径
其中几个选项的含义:
Generate the manifest file:是系统帮我们自动生成MANIFEST.MF文件,如果你的项目没有引用其他class-path,那可以选择这一项。
Use existing mainfest from workspace:这是可以选择我们自定义的.MF文件,格式如上所写,引用了第三方包时选用。
Seal content:要封装整个jar或者指定的包packet。
Main class:这里可以选择你的程序入口,将来打包出来的jar就是你这个入口类的执行结果。
最终生成jar包。
jar包中使用到的文件,放在jar包同路径下即可。
当我将生成的jar包以及用到的第三方jar包导入到新的工程中使用时,发生了各种报错,但是源码运行没有任何问题。当我开始怀疑是不是生成的jar包有问题时,发现是生成的jar包需要引用的第三包有问题,换用其他版本的第三方jar包之后,运行成功!