关于war包 jar包 ear包 及打包方法

2024-05-11 07:18
文章标签 方法 打包 jar war ear

本文主要是介绍关于war包 jar包 ear包 及打包方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

war包:是做好一个web应用后,通常是网站打成包部署到容器中
jar包:通常是开发的时候要引用的通用类,打成包便于存放管理。
ear包:企业级应用 通常是EJB打成ear包
各种包的打法:
转:
兄弟,对java着迷吗,或者是为了自己的生计,不论怎样都欢迎你进入精彩java世界,welcome!可能你刚刚对每个人说:Hello World!也或者……ok!这已经足够了。那就让我们开始吧,开始这个魔幻世界的旅程: 

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

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

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

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

先打开命令提示符(win2000或在运行筐里执行cmd命令,win98为DOS提示符),输入jar –help,然后回车(如果你盘上已经有了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 

这样我们使用了我们自己的MANIFEST.MF文件对原来默认的进行了更新。你不妨可以再进去看看是不是添上了Main-Class: HelloWorld这一句。 

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("<HTML>"); 
out.println("<HEAD><TITLE>Hello, World!</TITLE></HEAD>"); 
out.println("<BODY>"); 
out.println("Hello, World!"); 
out.println("</BODY></HTML>"); 
} 
}//end here! 




对它编译。下面是web.xml: 

<?xml version="1.0" encoding="ISO-8859-1"?> 
<!DOCTYPE web-app PUBLIC 
'-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN' 
'http://java.sun.com/j2ee/dtds/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> 




开始压缩,形成war档: 

在命令提示符下进到先前创制的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> 




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

我上传了上面打过的两个包,hello.jar和hello.war。 『 点击下载 』 

『 点击下载 』 

第一rar文件对应的是hello.jar,下载后将其名改为hello.jar 
第二rar文件对应hello.war,下载后改为hello.war。 
这是由于上传不了jar格式和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.
参考资料:http://www.blog.sh/user3/janson1983/archives/2006/47519.html

这篇关于关于war包 jar包 ear包 及打包方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/978863

相关文章

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

springboot3打包成war包,用tomcat8启动

1、在pom中,将打包类型改为war <packaging>war</packaging> 2、pom中排除SpringBoot内置的Tomcat容器并添加Tomcat依赖,用于编译和测试,         *依赖时一定设置 scope 为 provided (相当于 tomcat 依赖只在本地运行和测试的时候有效,         打包的时候会排除这个依赖)<scope>provided

浅谈主机加固,六种有效的主机加固方法

在数字化时代,数据的价值不言而喻,但随之而来的安全威胁也日益严峻。从勒索病毒到内部泄露,企业的数据安全面临着前所未有的挑战。为了应对这些挑战,一种全新的主机加固解决方案应运而生。 MCK主机加固解决方案,采用先进的安全容器中间件技术,构建起一套内核级的纵深立体防护体系。这一体系突破了传统安全防护的局限,即使在管理员权限被恶意利用的情况下,也能确保服务器的安全稳定运行。 普适主机加固措施:

webm怎么转换成mp4?这几种方法超多人在用!

webm怎么转换成mp4?WebM作为一种新兴的视频编码格式,近年来逐渐进入大众视野,其背后承载着诸多优势,但同时也伴随着不容忽视的局限性,首要挑战在于其兼容性边界,尽管WebM已广泛适应于众多网站与软件平台,但在特定应用环境或老旧设备上,其兼容难题依旧凸显,为用户体验带来不便,再者,WebM格式的非普适性也体现在编辑流程上,由于它并非行业内的通用标准,编辑过程中可能会遭遇格式不兼容的障碍,导致操

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

【北交大信息所AI-Max2】使用方法

BJTU信息所集群AI_MAX2使用方法 使用的前提是预约到相应的算力卡,拥有登录权限的账号密码,一般为导师组共用一个。 有浏览器、ssh工具就可以。 1.新建集群Terminal 浏览器登陆10.126.62.75 (如果是1集群把75改成66) 交互式开发 执行器选Terminal 密码随便设一个(需记住) 工作空间:私有数据、全部文件 加速器选GeForce_RTX_2080_Ti

maven 编译构建可以执行的jar包

💝💝💝欢迎莅临我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:「stormsha的主页」👈,「stormsha的知识库」👈持续学习,不断总结,共同进步,为了踏实,做好当下事儿~ 专栏导航 Python系列: Python面试题合集,剑指大厂Git系列: Git操作技巧GO

【VUE】跨域问题的概念,以及解决方法。

目录 1.跨域概念 2.解决方法 2.1 配置网络请求代理 2.2 使用@CrossOrigin 注解 2.3 通过配置文件实现跨域 2.4 添加 CorsWebFilter 来解决跨域问题 1.跨域概念 跨域问题是由于浏览器实施了同源策略,该策略要求请求的域名、协议和端口必须与提供资源的服务相同。如果不相同,则需要服务器显式地允许这种跨域请求。一般在springbo

AI(文生语音)-TTS 技术线路探索学习:从拼接式参数化方法到Tacotron端到端输出

AI(文生语音)-TTS 技术线路探索学习:从拼接式参数化方法到Tacotron端到端输出 在数字化时代,文本到语音(Text-to-Speech, TTS)技术已成为人机交互的关键桥梁,无论是为视障人士提供辅助阅读,还是为智能助手注入声音的灵魂,TTS 技术都扮演着至关重要的角色。从最初的拼接式方法到参数化技术,再到现今的深度学习解决方案,TTS 技术经历了一段长足的进步。这篇文章将带您穿越时

模版方法模式template method

学习笔记,原文链接 https://refactoringguru.cn/design-patterns/template-method 超类中定义了一个算法的框架, 允许子类在不修改结构的情况下重写算法的特定步骤。 上层接口有默认实现的方法和子类需要自己实现的方法