- 浏览: 429765 次
- 性别:
- 来自: 深圳
文章分类
最新评论
-
Glogo:
楼主您好,我在试验您的代码的时候发现新开的三个子线程并没有一直 ...
java 高并发 ReentrantLock -- 可重入的锁 -
univasity:
最近发觉也被限速了,投诉一下就好一会~~ 看来明天又要和电信M ...
ADSL上网速度慢 都是帐号限速惹的祸 -
liuyuanhui0301:
java 高并发 ReentrantLock -- 可重入的锁 -
dang_java:
呵.很好的说明文档.
JXTA技术与应用发展 -
helloqidi:
谢谢,学习了
SQL中exists和in的区别
JAR 文件格式以流行的 ZIP 文件格式为基础,用于将许多个文件聚集为一个文件。与 ZIP 文件不同的是,JAR 文件不仅用于压缩和发布,而且还用于部署和封装库、组件和插件程序,并可被像编译器和 JVM 这样的工具直接使用。在 JAR 中包含特殊的文件,如 manifests 和部署描述符,用来指示工具如何处理特定的 JAR。
一个 JAR 文件可以用于:
- 用于发布和使用类库
- 作为应用程序和扩展的构建单元
- 作为组件、applet 或者插件程序的部署单位
- 用于打包与组件相关联的辅助资源
JAR 文件格式提供了许多优势和功能,其中很多是传统的压缩格式如 ZIP 或者 TAR 所没有提供的。它们包括:
-
安全性。
可以对 JAR 文件内容加上数字化签名。这样,能够识别签名的工具就可以有选择地为您授予软件安全特权,这是其他文件做不到的,它还可以检测代码是否被篡改过。
-
减少下载时间。
如果一个 applet 捆绑到一个 JAR 文件中,那么浏览器就可以在一个 HTTP 事务中下载这个
applet 的类文件和相关的资源,而不是对每一个文件打开一个新连接。
-
压缩。
JAR 格式允许您压缩文件以提高存储效率。
-
传输平台扩展。
Java 扩展框架 (Java Extensions Framework) 提供了向 Java 核心平台添加功能的方法,这些扩展是用
JAR 文件打包的 (Java 3D 和 JavaMail 就是由 Sun 开发的扩展例子 )。
-
包密封。
存储在 JAR 文件中的包可以选择进行
密封
,以增强版本一致性和安全性。密封一个包意味着包中的所有类都必须在同一
JAR 文件中找到。
-
包版本控制。
一个 JAR 文件可以包含有关它所包含的文件的数据,如厂商和版本信息。
- 可移植性。 处理 JAR 文件的机制是 Java 平台核心 API 的标准部分。
jar
工具 ( 有关细节参阅
jar
工具
) 在默认情况下压缩文件。未压缩的
JAR 文件一般可以比压缩过的 JAR 文件更快地装载,因为在装载过程中要解压缩文件,但是未压缩的文件在网络上的下载时间可能更长。
大多数 JAR 文件包含一个 META-INF 目录,它用于存储包和扩展的配置数据,如安全性和版本信息。Java 2 平台识别并解释 META-INF 目录中的下述文件和目录,以便配置应用程序、扩展和类装载器:
-
MANIFEST.MF。
这个
manifest 文件
定义了与扩展和包相关的数据。
-
INDEX.LIST。
这个文件由
jar
工具的新选项-i
生成,它包含在应用程序或者扩展中定义的包的位置信息。它是 JarIndex 实现的一部分,并由类装载器用于加速类装载过程。
-
xxx
.SF。
这是 JAR 文件的签名文件。占位符
xxx
标识了签名者。
- xxx .DSA。 与签名文件相关联的签名程序块文件,它存储了用于签名 JAR 文件的公共签名。
为了用 JAR 文件执行基本的任务,要使用作为 Java Development Kit 的一部分提供的 Java Archive Tool
(
jar
工具 )。用
jar
命令调用
jar
工具。表 1
显示了一些常见的应用:
功能 | 命令 |
用一个单独的文件创建一个 JAR 文件 | jar cf jar-file input-file... |
用一个目录创建一个 JAR 文件 | jar cf jar-file dir-name |
创建一个未压缩的 JAR 文件 | jar cf0 jar-file dir-name |
更新一个 JAR 文件 | jar uf jar-file input-file... |
查看一个 JAR 文件的内容 | jar tf jar-file |
提取一个 JAR 文件的内容 | jar xf jar-file |
从一个 JAR 文件中提取特定的文件 | jar xf jar-file archived-file... |
运行一个打包为可执行 JAR 文件的应用程序 | java -jar app.jar |
一个 可执行的 jar 文件是一个自包含的 Java 应用程序,它存储在特别配置的 JAR 文件中,可以由 JVM 直接执行它而无需事先提取文件或者设置类路径。要运行存储在非可执行的 JAR 中的应用程序,必须将它加入到您的类路径中,并用名字调用应用程序的主类。但是使用可执行的 JAR 文件,我们可以不用提取它或者知道主要入口点就可以运行一个应用程序。可执行 JAR 有助于方便发布和执行 Java 应用程序。
创建一个可执行 JAR 很容易。首先将所有应用程序代码放到一个目录中。假设应用程序中的主类是
com.mycompany.myapp.Sample
。您要创建一个包含应用程序代码的
JAR 文件并标识出主类。为此,在某个位置 ( 不是在应用程序目录中 ) 创建一个名为
manifest
的文件,并在其中加入以下一行:
Main-Class: com.mycompany.myapp.Sample |
然后,像这样创建 JAR 文件:
jar cmf manifest ExecutableJar.jar application-dir |
所要做的就是这些了 -- 现在可以用
java -jar
执行这个 JAR 文件 ExecutableJar.jar。
一个可执行的 JAR 必须通过 menifest 文件的头引用它所需要的所有其他从属 JAR。如果使用了
-jar
选项,那么环境变量 CLASSPATH 和在命令行中指定的所有类路径都被 JVM 所忽略。
既然我们已经将自己的应用程序打包到了一个名为 ExecutableJar.jar 的可执行 JAR 中了,那么我们就可以用下面的命令直接从文件启动这个应用程序:
java -jar ExecutableJar.jar |
密封 JAR 文件中的一个包意味着在这个包中定义的所有类都必须在同一个 JAR 文件中找到。这使包的作者可以增强打包类之间的版本一致性。密封还提供了防止代码篡改的手段。
要密封包,需要在 JAR 的 manifest 文件中为包添加一个
Name
头,然后加上值为“true”的
Sealed
头。与可执行的 JAR 一样,可以在创建 JAR 时,通过指定一个具有适当头元素的 manifest 文件密封一个
JAR,如下所示:
Name: com/samplePackage/ Sealed: true |
Name
头标识出包的相对路径名。它以一个“/”结束以与文件名区别。在
Name
头后面第一个空行之前的所有头都作用于在
Name
头中指定的文件或者包。在上述例子中,因为
Sealed
头出现在
Name
头后并且中间没有空行,所以
Sealed
头将被解释为只应用到包
com/samplePackage
上。
如果试图从密封包所在的 JAR 文件以外的其他地方装载密封包中的一个类,那么 JVM 将抛出一个
SecurityException
。
扩展打包
扩展为 Java 平台增加了功能,在 JAR 文件格式中已经加入了扩展机制。扩展机制使得 JAR 文件可以通过 manifest 文件中的
Class-Path
头指定所需要的其他 JAR 文件。
假设 extension1.jar 和 extension2.jar 是同一个目录中的两个 JAR 文件,extension1.jar 的 manifest 文件包含以下头:
Class-Path: extension2.jar |
这个头表明 extension2.jar 中的类是 extension1.jar 中的类的 扩展类 。extension1.jar 中的类可以调用 extension2.jar 中的类,并且不要求 extension2.jar 处在类路径中。
在装载使用扩展机制的 JAR 时,JVM 会高效而自动地将在
Class-Path
头中引用的 JAR 添加到类路径中。不过,扩展 JAR 路径被解释为相对路径,所以一般来说,扩展 JAR 必须存储在引用它的 JAR 所在的同一目录中。
例如,假设类
ExtensionClient
引用了类
ExtensionDemo
, 它捆绑在一个名为
ExtensionClient.jar 的 JAR 文件中,而类
ExtensionDemo
则捆绑在 ExtensionDemo.jar
中。为了使 ExtensionDemo.jar 可以成为扩展,必须将 ExtensionDemo.jar 列在 ExtensionClient.jar
的 manifest 的
Class-Path
头中,如下所示:
Manifest-Version: 1.0 Class-Path: ExtensionDemo.jar |
在这个 manifest 中
Class-Path
头的值是没有指定路径的 ExtensionDemo.jar,表明 ExtensionDemo.jar 与 ExtensionClient JAR 文件处在同一目录中。
JAR 文件可以用
jarsigner
工具或者直接通过
java.security
API
签名。一个签名的 JAR 文件与原来的 JAR 文件完全相同,只是更新了它的 manifest,并在 META-INF 目录中增加了两个文件,一个签名文件和一个签名块文件。
JAR 文件是用一个存储在
Keystore
数据库中的证书签名的。存储在 keystore 中的证书有密码保护,必须向
jarsigner
工具提供这个密码才能对 JAR 文件签名。
JAR 的每一位签名者都由在 JAR 文件的 META-INF 目录中的一个具有 .SF 扩展名的签名文件表示。这个文件的格式类似于 manifest 文件 -- 一组 RFC-822 头。如下所示,它的组成包括一个主要部分,它包括了由签名者提供的信息、但是不特别针对任何特定的 JAR 文件项,还有一系列的单独的项,这些项也必须包含在 menifest 文件中。在验证一个签名的 JAR 时,将签名文件的摘要值与对 JAR 文件中的相应项计算的摘要值进行比较。
清单 1. 签名 JAR 中的 Manifest 和 signature 文件
Contents of signature file META-INF/MANIFEST.MF Manifest-Version: 1.0 Created-By: 1.3.0 (Sun Microsystems Inc.) Name: Sample.java SHA1-Digest: 3+DdYW8INICtyG8ZarHlFxX0W6g= Name: Sample.class SHA1-Digest: YJ5yQHBZBJ3SsTNcHJFqUkfWEmI= Contents of signature file META-INF/JAMES.SF Signature-Version: 1.0 SHA1-Digest-Manifest: HBstZOJBuuTJ6QMIdB90T8sjaOM= Created-By: 1.3.0 (Sun Microsystems Inc.) Name: Sample.java SHA1-Digest: qipMDrkurQcKwnyIlI3Jtrnia8Q= Name: Sample.class SHA1-Digest: pT2DYby8QXPcCzv2NwpLxd8p4G4= |
一个数字签名是 .SF 签名文件的已签名版本。数字签名文件是二进制文件,并且与 .SF 文件有相同的文件名,但是扩展名不同。根据数字签名的类型 -- RSA、DSA 或者 PGP -- 以及用于签名 JAR 的证书类型而有不同的扩展名。
要签名一个 JAR 文件,必须首先有一个私钥。私钥及其相关的公钥证书存储在名为
keystores
的、有密码保护的数据库中。JDK
包含创建和修改 keystores 的工具。keystore 中的每一个密钥都可以用一个别名标识,它通常是拥有这个密钥的签名者的名字。
所有 keystore 项 ( 密钥和信任的证书项 ) 都是用唯一别名访问的。别名是在用
keytool -genkey
命令生成密钥对 ( 公钥和私钥 ) 并在 keystore 中添加项时指定的。之后的
keytool
命令必须使用同样的别名引用这一项。
例如,要用别名“james”生成一个新的公钥 / 私钥对并将公钥包装到自签名的证书中,要使用下述命令:
keytool -genkey -alias james -keypass jamespass -validity 80 -keystore jamesKeyStore -storepass jamesKeyStorePass |
这个命令序列指定了一个初始密码“jamespass”,后续的命令在访问 keystore “jamesKeyStore”中与别名“james”相关联的私钥时,就需要这个密码。如果 keystore“jamesKeyStore”不存在,则
keytool
会自动创建它。
jarsigner
工具使用 keystore 生成或者验证 JAR 文件的数字签名。
假设像上述例子那样创建了 keystore “jamesKeyStore”,并且它包含一个别名为“james”的密钥,可以用下面的命令签名一个 JAR 文件:
jarsigner -keystore jamesKeyStore -storepass jamesKeyStorePass -keypass jamespass -signedjar SSample.jar Sample.jar james |
这个命令用密码“jamesKeyStorePass”从名为“jamesKeyStore”的 keystore 中提出别名为“james”、密码为“jamespass”的密钥,并对 Sample.jar 文件签名、创建一个签名的 JAR -- SSample.jar。
jarsigner
工具还可以验证一个签名的 JAR 文件,这种操作比签名 JAR 文件要简单得多,只需执行以下命令:
jarsigner -verify SSample.jar |
如果签名的 JAR 文件没有被篡改过,那么
jarsigner
工具就会告诉您 JAR 通过验证了。否则,它会抛出一个
SecurityException
, 表明哪些文件没有通过验证。
还可以用
java.util.jar
和
java.security
API 以编程方式签名
JAR( 有关细节参阅
参考资料
)。也可以使用像 Netscape Object Signing
Tool 这样的工具。
如果一个应用程序或者 applet 捆绑到多个 JAR 文件中,那么类装载器就使用一个简单的线性搜索算法搜索类路径中的每一个元素,这使类装载器可能要下载并打开许多个 JAR 文件,直到找到所要的类或者资源。如果类装载器试图寻找一个不存在的资源,那么在应用程序或者 applet 中的所有 JAR 文件都会下载。对于大型的网络应用程序和 applet,这会导致启动缓慢、响应迟缓并浪费带宽。
从 JDK 1.3 以后,JAR 文件格式开始支持索引以优化网络应用程序中类的搜索过程,特别是 applet。JarIndex 机制收集在 applet 或者应用程序中定义的所有 JAR 文件的内容,并将这些信息存储到第一个 JAR 文件中的索引文件中。下载了第一个 JAR 文件后,applet 类装载器将使用收集的内容信息高效地装载 JAR 文件。这个目录信息存储在根 JAR 文件的 META-INF 目录中的一个名为 INDEX.LIST 的简单文本文件中。
创建一个 JarIndex
可以通过在
jar
命令中指定
-i
选项创建一个 JarIndex。假设我们的目录结构如下图所示:
您将使用下述命令为 JarIndex_Main.jar、JarIndex_test.jar 和 JarIndex_test1.jar 创建一个索引文件:
jar -i JarIndex_Main.jar JarIndex_test.jar SampleDir/JarIndex_test1.jar |
INDEX.LIST 文件的格式很简单,包含每个已索引的 JAR 文件中包含的包或者类的名字,如清单 2 所示:
清单 2. JarIndex INDEX.LIST 文件示例
JarIndex-Version: 1.0 JarIndex_Main.jar sp JarIndex_test.jar Sample SampleDir/JarIndex_test1.jar org org/apache org/apache/xerces org/apache/xerces/framework org/apache/xerces/framework/xml4j |
1. 签名前
通常情况下,在签名前META-INF目录下只有一个MANIFEST.MF文件,文件中只有很少的内容,例如:
Manifest-Version: 1.0
Main-Class: CreateFile
2. 签名后
签名后,会在META-INF目录下增加两个新的文件,一个是签名文件,后缀名为.SF;一个为签名块文件,后缀取决你 签名时使用的算法,例如使用RSA来签名,那么这个签名块文件的后缀为.RSA。这两个文件的命名取决于签名时使用的alias,例如如果使用一个 keystore的别名Minliang来做签名,那么这两个文件名均为MINLIANG。除此之外,原先的MANIFEST.MF文件也会被相应的更 新。也就是说,在签名后,META-INF目录下的文件有:MANIFEST.MF,签名文件,签名块文件。
MANIFEST.MF:
签名时,把JAR包中除META-INF目录之外的所有文件的Message Digest信息添加到该文件中。这些信息与JAR包中的文件实体是一一对应的。例如:第一个digest信息是第一个文件的Message Digest,第二个digest信息是第一个文件和第二个文件内容之和的Message Digest,等等。在该文件中的信息并没有用密钥进行加密,而只是各个文件的Message Digest信息。
Manifest-Version: 1.0
Main-Class: CreateFile
Name: .classpath
SHA1-Digest: uPbF74ItpohxnbWsy2MpLImqtkA=
Name: CreateFile.class
SHA1-Digest: 0KIj80fzZUV4tgdrNE+luxnTsJY=
Name: FileWriter.class
SHA1-Digest: YGXJEXvSfZah/WM4TXFLKaoqYbA=
Name: .project
SHA1-Digest: U2Iniw7wANpE8+pMCgzUzIMHOnU=
签名文件:
一个签名文件就是一个MANIFEST.MF文件被签名的版本,通过该文件,Jar verifier 可以察觉任何的增加未签名文件的操作。签名文件在SHA1-Digest-Manifest 头 包含了MANIFEST.MF文件的message digest,此外还包含了在MANIFEST.MF文件所列出的各个文件的message digest。这与MANIFEST.MF文件的构成很相似,只不过签名文件中的message digest是基于MANIFEST.MF文件中的内容进行计算的,而MANIFEST.MF文件中的message digest是基于Jar包中的文件内容本身进行计算的。
Signature-Version: 1.0
SHA1-Digest-Manifest: h1yS+K9T7DyHtZrtI+LxvgqaMYM=
Created-By: SignatureFile JDK 1.2
Name: a/b/c1.class
SHA1-Digest: fcav7ShIG6i86xPepmitOVo4vWY=
Name: a/b/c2.class
SHA1-Digest: xrQem9snnPhLySDiZyclMlsFdtM=
签名块文件:
签名块文件必须随同签名文件一起创建。在该文件中,以不可读的格式纪录了与签名密钥相对应的公钥以及证书签名链。通过该签名块文件可以对Jar包中的文件进行检验。
发表评论
-
Android 数字签名学习笔记
2012-04-25 11:03 990在 Android系统中,所有安装到系统的应用程序都必有 ... -
序列化:serializable,hessian,protobuf性能对比
2011-10-31 17:08 1261分布式应用系统中,系统之间的通讯的质量决定了系统的可用性 ... -
SSL双向认证java实现
2011-10-17 23:49 1024本文通过模拟场景,介绍SSL双向认证的java实现默认的情况下 ... -
Benchmark Analysis: Guice vs Spring
2011-04-19 14:35 1048The original link can be found ... -
Java Network Launching Protocol
2011-04-18 17:43 942在java开发的早期,重点被放在了客户端开发。语言中对于app ... -
NIO 包及工作原理
2011-03-11 11:14 1755NIO 包及工作原理 针对 ... -
使用Java NIO编写高性能的服务器
2011-03-11 01:19 815从JDK 1.4开始,Java的标 ... -
RMI, RMI-IIOP,JNDI
2009-05-21 17:31 15281. RMI-IIOP(Java Remote ... -
企业中的 RMI-IIOP
2009-05-21 17:13 1017RMI 和 CORBA 常被视 ... -
JMX
2009-05-21 15:44 1009JMX规范 1.1 J ... -
使用Eclipse IDE的技巧
2009-02-24 11:00 1797使用Eclipse IDE的技巧 作 ... -
spring quartz 动态定时任务
2009-01-22 13:31 4507什么是动态定时任务:是由客户制定生成的,服务端只知道该去执行什 ... -
基于struts+spring+ibatis的轻量级
2009-01-12 16:21 1040基于struts+spring+ibatis的轻量级J2 ... -
Log4j配置实例[经典]
2009-01-12 14:53 1290Log4j配置实例[经典] 0 推荐 ... -
jbpm工作流学习心得
2008-09-19 13:59 1304一,装载流程: 第一种: java 代码 JbpmCo ... -
jbpm请假工作流
2008-09-19 13:56 1855请假流程(备用) 工作中要用到JBPM写工作流,自习的时 ... -
利用JExcel API操作EXCEL文件
2008-09-08 10:52 1475使用Windows操作系统的朋 ... -
jExcel API讲解
2008-09-08 10:51 1495转自:http://jhobby.iteye.com/blog ... -
Tomcat5.0乱码全解决方案
2008-09-02 11:56 1102http://hi.baidu.com/liet2008/bl ... -
Linux_Macintosh 平台下 Eclipse 环境中的 JNI 混合语言调试
2008-08-28 18:27 1496Linux_Macintosh 平台下 Eclipse ...
相关推荐
1. **类文件浏览器**:用户可以通过图形界面浏览.jar文件中的所有类,查看每个类的详细结构,包括常量池、字段、方法、属性等。 2. **字节码解释器**:将字节码指令转换成易于理解的文本,对于理解程序运行逻辑有很...
《StegSolve.jar:揭秘图像中的隐藏信息》 在信息技术日益发达的今天,数据的安全性和隐私保护成为了人们关注的焦点。在这个背景下,隐藏信息的技术,即隐写术(Steganography),应运而生。其中,LSB(Least ...
- **MANIFEST.MF**: 在 JAR 文件的 `MANIFEST.MF` 文件中,`Main-Class` 指定为 `org.springframework.boot.loader.JarLauncher`,这是 Spring Boot 启动的入口点。`Start-Class` 指定为应用的主类,例如 `...
二、Hessian 4.0.7-src.jar——源代码揭秘 `hessian-4.0.7-src.jar`则提供了Hessian 4.0.7的源代码,这对于开发者来说是宝贵的资源。通过查看源码,我们可以深入了解Hessian的工作原理,包括如何进行序列化和反序列...
- 如果源码包含了第三方库(如aar或jar文件),这可能是开发者为了实现特定功能(如网络请求、数据库操作等)而引入的。通过查看build.gradle文件,我们可以看到项目的依赖关系,了解如何管理和使用这些库。 5. **...
自动配置使得开发者无需编写大量繁琐的XML配置文件,而是通过“@EnableAutoConfiguration”注解自动加载合适的配置。起步依赖是Spring Boot提供的Maven或Gradle插件,它简化了项目构建过程,只需添加相应的依赖,...
-> "Preferences" -> "Java" -> "Installed JREs"进行配置,选择对应的JRE版本,并在"Default VM arguments"中添加参数"-javaagent:/path/to/net.sf.jadclipse_3.3.0.jar"(路径替换为实际的jar文件位置)。...
2. **独立运行**:Spring Boot应用程序包含内嵌的HTTP服务器(如Tomcat、Jetty或Undertow),可以打包成一个独立的JAR文件运行。 3. **无需XML配置**:Spring Boot不需要使用XML配置文件,尽管它仍然支持XML配置。 4...
《ZipCenOp.zip——揭秘压缩文件的伪加密与文件头修改技术》 在数字化的世界里,文件压缩技术是我们日常工作中不可或缺的一部分。其中,ZIP格式作为最常用的压缩格式之一,深受用户喜爱。本文将深入探讨“ZipCenOp....
10. **发布与部署**:最后,开发者需要了解如何将游戏打包成可安装的JAR文件,并通过各种渠道分发给用户,这可能涉及到与运营商的协作或者通过应用商店发布。 通过《顶尖J2ME手机游戏3D MotoRacer全程制作揭秘》这...
- **独立的应用程序**:Spring Boot项目可以被打包成可执行的JAR或WAR文件,易于部署和管理。 ### Spring Boot的工作原理 #### 自动配置机制 Spring Boot的核心特性之一是它的自动配置能力。当开发者添加某个库...
"Stegsolve.zip" 文件便是关于这一领域的工具包,它主要包含了名为 "Stegsolve.jar" 的Java可执行文件,用于帮助用户检测和提取隐藏在图像中的秘密信息。 隐写术是一种历史悠久的技术,但随着计算机科学的发展,其...
通过分析这两个jar文件,开发者不仅可以掌握即时通讯软件的基本架构,还能深入理解网络编程、并发处理、数据库操作等核心概念。对于希望构建自己社交平台或增强网络编程技能的开发者来说,这是一个宝贵的资源。同时...
"SnakeGame.exe"和"SnakeGame.jar"是游戏的执行文件,前者是Windows系统的可执行文件,后者是Java的可执行jar包,两者都可以启动游戏。"img_0156.jpg"可能是游戏中的一些资源图片,比如背景、图标或者其他游戏元素。...
《Stegsolve神级隐写图片提取器——揭秘隐藏在图像中的秘密》 在信息安全领域,尤其是在CTF(Capture The Flag)竞赛中,隐写术是一种至关重要的技术。隐写术,即在不改变原文件外观的前提下,将秘密信息隐藏在普通...
这涉及到J2ME的打包和发布流程,包括生成JAR和JAD文件,以及如何通过网络进行分发。JAD文件包含了游戏的基本信息,如版本号、作者、大小等,是用户下载和安装游戏的关键。 总结来说,这款J2ME飞行战机游戏源代码为...
7. **外部配置**:如何通过YAML或Properties文件、环境变量、命令行参数等方式进行外部配置。 8. **Actuator**:讲解如何使用Actuator提供的健康检查、审计、日志等监控功能。 9. **部署**:指导如何打包应用,...
3. **模块路径(Module Path)**:替代了传统的类路径,模块路径是由一系列模块组成的路径,这些模块被部署为`.jar`文件或目录。 4. **命名空间分离**:模块化引入了一种新的命名空间概念,即每个模块都有自己的...
7. **部署与测试**:包括如何打包应用为可执行的 JAR 或 WAR 文件,以及如何在各种环境中(如 Docker、Cloud)部署应用,同时也会介绍单元测试和集成测试的策略。 《Spring Boot 揭秘》可能更加深入,可能包含以下...