通过ANT生成MANIFEST.MF中的Class-Path属性

21 篇文章 0 订阅


之前做一个项目,主程序打包成一个jar文件,因为用到了很多第三方的lib包,所以直接通过java命令运行jar比较烦琐,通过研究jar中的MANIFEST.MF文件,我们发现其中一个Class-Path属性,但这个属性值比较奇怪,不支持正则。所以要配置使用到的第三方包,必须明确相对路径和包名。如果手写MANIFEST.MF,工作量会比较大。幸好ant可以帮我们自动生成Class-Path属性。具体的请看下面的ant的执行脚本

      第一步,定义一些属性

      1 <!-- name of the output .jar file -->

<property name="jar.name" value="ourjarfile.jar" />
 <!-- base directory for distribution target -->
 <property name="dist.home" value="dist" />
 <!-- base directory for compilation targets -->
 <property name="build.home" value="target" />
 <!-- The base directory for all libraries (jar) files -->
 <property name="lib.home" value="lib" />

第二步,创建主程序的jar文件,这里会创建Class-Path的属性,并生成相应的MANIFEST.MF

<target name="jar" depends="compile" description="Create jar and MANIFEST.MF">
 
  
 
   <!-- create a property containing all .jar files, prefix lib/, and seperated with a space -->
 
   <pathconvert property="libs.project" pathsep=" ">
 
     <mapper>
 
       <chainedmapper>
         <!-- remove absolute path -->
         <flattenmapper />
         <!-- add lib/ prefix -->
         <globmapper from="*" to="lib/*" />
       </chainedmapper>
     </mapper>
     <path>
       <!-- lib.home contains all jar files, in several subdirectories -->
       <fileset dir="${lib.home}">
         <include name="**/*.jar" />
       </fileset>
     </path>
   </pathconvert>
   <!-- create the jar -->
   <jar jarfile="${build.home}/${jar.name}" basedir="${build.home}/classes">
     <!-- define MANIFEST.MF -->
     <manifest>
       <attribute name="Built-By" value="${user.name}" />
       <attribute name="Main-Class" value="my.path.to.the.main.Application" />
       <section name="common">
         <attribute name="Specification-Title" value="${component.name}" />
         <attribute name="Specification-Version" value="${component.version}" />
         <attribute name="Specification-Vendor" value="${component.vendor}" />
         <attribute name="Implementation-Title" value="${component.name}" />
         <attribute name="Implementation-Version" value="${component.version} ${TODAY}" />
         <attribute name="Implementation-Vendor" value="${component.vendor}" />
       </section>
       <!-- finally, use the magically generated libs path -->
       <attribute name="Class-Path" value="${libs.project}" />
     </manifest>
   </jar>
 </target>

第三步,执行主程序,在控制台中输入 java -jar 主程序.jar -Xms128M -Xmx256m.在这里我们就不用一一输入主程序引用的第三方包了,我们已经在主程序jar中的MANIFEST.MF文件中定义了Class-Path属性,这里列出了所有的第三方包.


转载地址:http://www.cnblogs.com/51cto/archive/2010/06/23/1763878.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值