前言

你真的了解META-INF吗?

做过JAVA EE开发的工程师应该都知道在JAVA build出来的JAR或者WAR的顶层目录下有个META-INF文件夹吧,可是有多少人能够清楚说出这个文件夹到底是做神马的? What is the purpose of META-INF? 恐怕不是都能说的清楚准确吧。

Jar文件

开发中可以直接使用java class文件来运行程序,不过这样不太方便,所以出现了jar文件来提供发布和运行,jar文件实际上是class文件的zip压缩存档,有很多工具都可以操纵这种格式的文件,所以jar文件本身并不能表达应用程序的便签信息。

META-INF目录的出现

根据官方的JAR file specification(http://docs.oracle.com/javase/7/docs/technotes/guides/jar/jar.html), 一个典型的META-INF目录下可能包含如下几种文件或者子目录:

  • MANIFEST.MF
  • INDEX.LIST
  • x.SF
  • x.DSA
  • services/

    Manifest.mf

    为了提供存档的便签信息,出现了Manifest.mf文件,jar文件中有一个特定的目录来存放标签信息:META-INF目录,主要应关注其中一个名叫manifest.mf的文件,它包含了jar文件的内容描述,在应用程序运行时向JVM提供应用程序的信息

    关于MEATA-INF目录的作用,百度上的解释是这样的(正规的解释): META-INF相当于一个信息包,目录中的文件和目录获得Java 2平台的认可与解释,用来配置应用程序、扩展程序、类加载器和服务manifest.mf文件,在用jar打包时自动生成。

jar文件都有一个默认产生的META-INF目录和其中的manifest.mf文件 使用jar命令可以直接产生META-INF目录和manifest.mf文件,例如:

  1. Manifest-Version: 1.0 #生成的manifest.mf文件的版本
  2. Built-By: anin #文件的创建用户命名,在IDEA的配置文件中可以设置
  3. Created-By: IntelliJ IDEA #文件的生成者,一般由jar命令行工具生成,这里显示的时idea
  4. Build-Jdk: 1.8.0_144 #所使用的JDK环境

其实manifest.mf文件中的配置信息除了上面的四个之外,还是有很多的,以下是几个常见的属性:

  1. 一、一般属性
  2. 1Signature-Vresion:定义jar文件的签名版本
  3. 2Class-Path:内部的类搜索路径,提供给应用程序或者类装载器
  4. 二、应用程序的相关属性
  5. 1Main-Class:定义jar文件的入口类,该类必须可执行!一旦定义了该属性就可以使用
  6. java -jar 程序名.jar 来运行该jar文件

还有manifest.mf文件的格式 :::info

  1. manifest 文件中的每一行都是 key-value 对应的:属性名开头,接着是 “:” ,然后是属性值,每行最多72
  2. 个字符,如果需要增加,可以在下一行续行,续行以空格开头,以空格开头的行都会被视为前一行的续行。 :::