执行:
java -jar xxx.jar
运行一个jar包时,提示报错:
Invalid or corrupt jarfile
该jar之前一直是正常运行的,这次只是增加了一项图片处理功能,引入了opencv-2413.jar。除了class文件的变化之外,唯一的修改就是MANIFEST.MF文件了。分析来看,问题很可能就出在这个文件上,将该文件还原,果然,jar至少能启动了。
不就是MANIFEST.MF文件中类路径新添加了一个opencv吗,为什么会这样呢?
MANIFEST.MF是一个非常脆弱的文件,格式要求比较严格,一个空格、一个回车符,都可能会导致该文件失效,从而使得对应的jar包非法:Invalid or corrupt jarfile!
MANIFEST.MF格式要求:
1. 文件中的内容以key-value键值对的形式出现,key和value之间采用"英文冒号+空格"进行分隔,注意:冒号后的空格必须有;key必须顶格写,之前不能有空格。
2. 文件开头不能有空行,并且文件总是以Manifest-Version属性开头。
3. 文件必须以一个空行结束,注意:该空行不能有任何字符,包括空格。
4. 每行最长72个字符,如果超过的话,采用续行,换行继续必须以空格开头。
5. 对于Class-Path属性中的存在的路径,使用"/"分隔目录,与平台无关;多个jar包引用以空格分开。
针对MANIFEST.MF文件每行不能超过72个字符的说法,还有疑问。因为我的MANIFEST.MF文件中,Class-Path属性的很多行都是超过72个字符的,实际上并没有引起异常。
我的jar包之所以报错,就是违背了以上的第3条,文件虽然以空行结束,但该空行隐藏了一个空格,也就是上图中的第14行包含了一个空格。