Java进阶学习:jar打包详解_Java编程

文章来源:pconline 作者:fivesky

 jar文件听说过吗,没有?或者陌生!好,没关系,这就是我们的第一站:打包发布。  

   为什么会有这个玩意呢,首先,这是jar的全称:JavaTM Archive (JAR) file,是的,就是java存档文件。这有点类似zip文件,想一想它是干什么的用的呢,压缩!?没错就是要压缩,将我们原先零散的东西放到一下,重新组织,所有这些目的只有一个:方便!好了,不用管他是怎么压缩的,我们的重点是哪些是我们要压缩的(输入),还有压缩成了什么(输出),进而将它发布(部署)。   

  那我们的输入(要压缩的东西)主要是class文件,还有辅助的资源(这其中可能有图片,jsp文件,html文件等等)。Jar技术在jdk1.1版本中就已存在,在1.2中又有了增强。接下来说说jar的好处吧,这是官方的描述:安全,快速下载,压缩,猎取包,版本化包,可携。  

  说了这么多,我们现在开始实施。   

  先打开命令提示符(win2000或在运行框里执行cmd命令,win98为DOS提示符),输入jar Chelp,然后回车(如果你盘上已经有了jdk1.1或以上版本),看到什么:   

  用法:jar {ctxu}[vfm0Mi] [jar-文件] [manifest-文件] [-C 目录] 文件名 ...   

  选项:   

  -c 创建新的存档

  -t 列出存档内容的列表

  -x 展开存档中的命名的(或所有的〕文件

  -u 更新已存在的存档

  -v 生成详细输出到标准输出上

  -f 指定存档文件名

  -m 包含来自标明文件的标明信息

  -0 只存储方式;未用zip压缩格式

  -M 不产生所有项的清单(manifest〕文件

  -i 为指定的jar文件产生索引信息

  -C 改变到指定的目录,并且包含下列文件:  

  如果一个文件名是一个目录,它将被递归处理。   

  清单(manifest〕文件名和存档文件名都需要被指定,按'm' 和 'f'标志指定的相同顺序。   

  示例1:将两个class文件存档到一个名为 'classes.jar' 的存档文件中:

  jar cvf classes.jar Foo.class Bar.class  

  示例2:用一个存在的清单(manifest)文件 'mymanifest' 将 foo/ 目录下的所有文件存档到一个名为 'classes.jar' 的存档文件中:

  jar cvfm classes.jar mymanifest -C foo/ .  

  来个小例子试试看:

  我们只有一个HelloWorld,如下:   

  public class HelloWorld{
   public static void main(String[ ] args){
   System.out.println(“Hi, Hello World!”);
   }
   }

  

   将这个java文件存到C盘跟目录下,ok,接下来,

  在先前打开的命令提示符下(跳转到C盘提示符下),我们输入javac HelloWorld.java,然后继续输入:jar  cvf  hello.jar  HelloWorld.class,回车后去你的C盘看看,多了什么,没错 hello.jar 。

  基本的步骤我们现在都知道了,你可以自己去尝试一下随着jar后面的参数的不同,结果有什么变化。   
   紧接着我们看看如何运行我们的jar包。   

  在进入正题之前,你要先打开我们刚刚做好的jar包看看,多了什么呢,META-INF目录?再看看里面是什么,还有一个MANIFEST.MF文件是不是?用文本编辑器(我这里是UltraEdit)打开它看看:

  Manifest-Version: 1.0
   Created-By: 1.4.2 (Sun Microsystems Inc.)  

  就是这样。这里我们对它进行修改,加一句:Main-Class: HelloWorld (在第三行)。这个就是我们之前写的那个类,也就是我们的入口类。也即,

  Manifest-Version: 1.0
   Created-By: 1.4.2 (Sun Microsystems Inc.)
   Main-Class: HelloWorld  

  接下来,我们在命令提示符里执行:

  jar  umf  MANIFEST.MF  app.jar  (应该是hello.jar吧) 

  这样我们使用了我们自己的MANIFEST.MF文件对原来默认的进行了更新。你不妨可以再进去看看是不是添上了Main-Class: HelloWorld这一句。    (是吗,我怎么没试出来,提示java.io.FileNotFoundException:MANIFEST.MF(系统找不到指定的文件)怎么回事?)

 Ok,这个最后的一步了,来验证我们做的一切,在命令提示符中输入:

  java -jar hello.jar(执行)  

  出现了什么, Hi, Hello World!  

  我们再来看看jar文件在tomcat中发布,注意:在tomcat中我们就不能再用jar这种格式,而改war格式,它是专门用于web应用的,其实整个过程下来基本上和jar是类似的: 

  先准备我们要打包的资源。   

  找到存放tomcat的webapps目录,进到其中,新建一个文件夹,这里命名为hello,再进去新建WEB-INF文件夹,再进去新建classes文件夹,此时我们也将我们唯一的servlet,HelloWorld.java放到这里,在与classes目录同级下建立一文件web.xml。Ok,目前我们初步建立了一个简单的web应用。  

  这是HelloWorld.java:   

  import java.io.*;
   import javax.servlet.*;
   import javax.servlet.http.*;
   public class HelloWorld extends HttpServlet {
   public void doGet(HttpServletRequest req, HttpServletResponse res)
   throws ServletException, IOException {
   res.setContentType("text/html");
   PrintWriter out = res.getWriter();
   out.println("");
   out.println("");
   out.println("");
   out.println("Hello, World!");
   out.println("");
   }
   }//end here!  

  对它编译。下面是web.xml:
  
<?xml version="1.0" encoding="UTF-8"?>
  
<!DOCTYPE web-app PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN" "http://java.sun.com/dtd/web-app_2_3.dtd">
  
<web-app>
  
<servlet>
  
<servlet-name>hello</servlet-name>
  
<servlet-class>HelloWorld</servlet-class>
  
</servlet>
  
<servlet-mapping>
  
<servlet-name>hello</servlet-name>
  
<url-pattern>/HelloWorld</url-pattern>
  
</servlet-mapping>
  
</web-app>

  在命令提示符下进到先前创制的hello目录下,执行 jar cvf hello.war * ,我们便得到hello.war。将它拷贝至webapps目录下,ok,来看最后一步,打开tomcat的目录conf中的server.xml,加入:

  <Context path="/hello" docBase="hello.war" debug="0" reloadable="true"/>

   大功告成!运行它,启动tomcat,后在浏览器中输入http://localhost:8080/hello/HelloWorld,有了吗? 

  最后,如果你想用ant来完成以上的打包活动,下面就告诉你:
   对于jar来说。在build.xml中,

  <target name="jar">
  
<jar destfile="${app_home}/hello.jar">
  
<fileset dir="${dest}" includes="**"/>
  
<!--fileset dir="${dest}" includes="**/action.properties"/-->
  
</jar>
  
</target>  

   对于war,

  <war warfile="hello.war" webxml="./WEB-INF/web.xml">
  
<fileset dir="html"/>
  
<lib dir="lib/">
  
<exclude name="oracle*.jar"/>
  
</lib>
  
<classes dir="build/servlets">
  
<include name="**/*.class"/>
  
</classes>
  
</war>  

   好了,就这么多,希望对你有点帮助。:)

  补充: 

  jar基本操作:   

  1. 创建jar文件  

  jar cf jar-file input-file(s)
   c---want to Create a JAR file.
   f---want the output to go to a file rather than to stdout.
   eg: 1)jar cf myjar.jar query_maintain_insert.htm
   2)jar cvf myjar.jar query_maintain_insert.htm
   v---Produces verbose(详细的) output.
  3)jar cvf myjar.jar query_maintain_insert.htm mydirectory
   4)jar cv0f myjar.jar query_maintain_insert.htm mydirectory
   0---don't want the JAR file to be compressed.
   5)jar cmf MANIFEST.MF myjar.jar yahh.txt
   m---Used to include manifest information from an existing manifest file.
   6)jar cMf MANIFEST.MF myjar.jar yahh.txt
   M---the default manifest file should not be produced.
   7)jar cvf myjar.jar *
   *---create all contents in current directory. 

  2. 察看jar文件   

  jar tf jar-file
   t---want to view the Table of contents of the JAR file.
   eg: 1)jar vft yahh.jar
   v---Produces verbose(详细的) output.  

  3. 提取jar文件  

  jar xf jar-file [archived-file(s)]
   x---want to extract files from the JAR archive.
   eg: 1)jar xf yahh.jar yahh.txt(仅提取文件yahh.txt)

  2)jar xf yahh.jar alex/yahhalex.txt(仅提取目录alex下的文件yahhalex.txt)  

  3)jar xf yahh.jar(提取该jar包中的所有文件或目录)  

  4. 修改Manifest文件  

  jar cmf manifest-addition jar-file input-file(s)
   m---Used to include manifest information from an existing manifest file.  

  5. 更新jar文件  

  jar uf jar-file input-file(s)
   u---want to update an existing JAR file.
时间: 2024-11-18 21:55:02

Java进阶学习:jar打包详解_Java编程的相关文章

基于Java中字符串内存位置详解_java

前言 之前写过一篇关于JVM内存区域划分的文章,但是昨天接到蚂蚁金服的面试,问到JVM相关的内容,解释一下JVM的内存区域划分,这部分答得还不错,但是后来又问了Java里面String存放的位置,之前只记得String是一个不变的量,应该是要存放在常量池里面的,但是后来问到new一个String出来应该是放到哪里的,这个应该是放到堆里面的,后来又问到String的引用是放在什么地方的,当时傻逼的说也是放在堆里面的,现在总结一下:基本类型的变量数据和对象的引用都是放在栈里面的,对象本身放在堆里面,

Java中Properties的使用详解_java

Java中有个比较重要的类Properties(Java.util.Properties),主要用于读取Java的配置文件,各种语言都有自己所支 持的配置文件,配置文件中很多变量是经常改变的,这样做也是为了方便用户,让用户能够脱离程序本身去修改相关的变量设置.今天,我们就开始Properties的使用. Java中Properties的使用 Properties的文档说明: The Properties class represents a persistent set of propertie

Java静态方法不具有多态性详解_java

动态绑定机制使得基类的引用能够指向正确的子类对象,从而使得面向基类编程成为可能. 然而动态绑定在以下两种情况会失效. 1.基类方法是private或final修饰的 这个很好理解,因为private说明该方法对子类是不可见的,子类再写一个同名的方法并不是对父类方法进行复写(Override),而是重新生成一个新的方法,也就不存在多态的问题了.同理也可以解释final,因为方法同样是不可覆盖的. 2.方法是static修饰的 代码如下所示. class Base { public static v

Java 23种设计模型详解_java

设计模式(Design Patterns)                                   --可复用面向对象软件的基础 设计模式(Design pattern)是一套被反复使用.多数人知晓的.经过分类编目的.代码设计经验的总结.使用设计模式是为了可重用代码.让代码更容易被他人理解.保证代码可靠性. 毫无疑问,设计模式于己于他人于系统都是多赢的,设计模式使代码编制真正工程化,设计模式是软件工程的基石,如同大厦的一块块砖石一样.项目中合理的运用设计模式可以完美的解决很多问题,每

java 设计模型之单例模式详解_java

Singleton 模式的宗旨在于确保某个类只有一个实例,别且为之提供一个全局访问点.为了防止其他工作人员实例化我们的类, 可以为该类创建唯一一个构造器,并将构造器的可见设置为私有.值得注意的是,如果我们创建了其他的非私有的构造器,或者根本没有为该类提 供构造器,那么其他人员还是能实例化我们的类. 如果不希望提前创建单例对象,我们可以等到第一次使用该单例对象的时候在创建它,即 滞后初始化.滞后初始化单例对象有两个理由: 1.也许在静态初始化时间,你没有关于如何初始化单例对象的足够信息. 2.选择

Java中JSON字符串与java对象的互换实例详解_java

在开发过程中,经常需要和别的系统交换数据,数据交换的格式有XML.JSON等,JSON作为一个轻量级的数据格式比xml效率要高,XML需要很多的标签,这无疑占据了网络流量,JSON在这方面则做的很好,下面先看下JSON的格式, JSON可以有两种格式,一种是对象格式的,另一种是数组对象, {"name":"JSON","address":"北京市西城区","age":25}//JSON的对象格式的字符串 [

Java 中Map 的用法详解_java

Map简介 将键映射到值的对象.一个映射不能包含重复的键:每个键最多只能映射到一个值.此接口取代 Dictionary 类,后者完全是一个抽象类,而不是一个接口. Map 接口提供三种collection 视图,允许以键集.值集或键-值映射关系集的形式查看某个映射的内容.映射顺序 定义为迭代器在映射的 collection 视图上返回其元素的顺序.某些映射实现可明确保证其顺序,如 TreeMap 类:另一些映射实现则不保证顺序,如HashMap 类. 注:将可变对象用作映射键时必须格外小心.当对

Java实现调用MySQL存储过程详解_java

前言 存储过程(Stored Procedure)是存储在数据库中经过第一次编译后再次调用不需要再次编译,用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它. Java调用MySQL的存储过程,需要用JDBC连接,环境eclipse 首先查看MySQL中的数据库的存储过程,接着编写代码调用 mysql> show procedure status; +------+-------------+-----------+----------------+-------------

Java线程间的通信方式详解_java

本总结我对于JAVA多线程中线程之间的通信方式的理解,主要以代码结合文字的方式来讨论线程间的通信,故摘抄了书中的一些示例代码,具体内容如下 ①同步 这里讲的同步是指多个线程通过synchronized关键字这种方式来实现线程间的通信. 参考示例: public class MyObject { synchronized public void methodA() { //do something.... } synchronized public void methodB() { //do so