下载扩展程序

原文: https://docs.oracle.com/javase/tutorial/ext/basics/download.html

下载扩展是 JAR 文件中的类(和相关资源)的集合。 JAR 文件的清单可以包含引用一个或多个下载扩展的标头。可以通过以下两种方式之一引用扩展:

  • 通过Class-Path标头
  • 通过Extension-List标题

请注意,清单中最多允许使用其中一个。由Class-Path标头指示的下载扩展名仅在下载它们的应用程序的生命周期内下载,例如 Web 浏览器。它们的优点是客户端没有安装任何东西;它们的缺点是每次需要时都会下载它们。由Extension-List标题下载的下载扩展名安装在下载它们的 JRE 的/ lib / ext目录中。它们的优点是它们在第一次需要时下载;随后它们可以在不下载的情况下使用但是,如本教程后面所示,部署它们会更复杂。

由于使用Class-Path标头的下载扩展更简单,我们首先考虑它们。例如,假设a.jarb.jar是同一目录中的两个 JAR 文件,并且a.jar的清单包含此标题:

  1. Class-Path: b.jar

然后b.jar中的类作为a.jar中类的扩展类。 a.jar中的类可以调用b.jar中的类而不需要b.jar的类必须在类路径上命名。 a.jar本身可能是也可能不是扩展名。如果b.jara.jar不在同一目录中,那么Class-Path标题的值应该设置为相对路径名b.jar

正在扮演下载扩展的字符的类没有什么特别之处。它们被视为扩展,仅仅因为它们被其他 JAR 文件的清单引用。

为了更好地理解下载扩展如何工作,让我们创建一个并将其用于使用。

一个例子

假设您要创建一个使用上一节RectangleArea类的 applet:

  1. public final class RectangleArea {
  2. public static int area(java.awt.Rectangle r) {
  3. return r.width * r.height;
  4. }
  5. }

在上一节中,您将RectangleArea类放入已安装的扩展中,方法是将包含它的 JAR 文件放入 JRE 的lib / ext目录中。通过使其成为已安装的扩展,您启用了任何应用程序以使用RectangleArea类,就好像它是 Java 平台的一部分一样。

如果您希望能够从 applet 使用RectangleArea类,情况会有所不同。例如,假设你有一个 applet,AreaApplet,它使用了类RectangleArea

  1. import java.applet.Applet;
  2. import java.awt.*;
  3. public class AreaApplet extends Applet {
  4. Rectangle r;
  5. public void init() {
  6. int width = 10;
  7. int height = 5;
  8. r = new Rectangle(width, height);
  9. }
  10. public void paint(Graphics g) {
  11. g.drawString("The rectangle's area is "
  12. + RectangleArea.area(r), 10, 10);
  13. }
  14. }

此 applet 实例化 10 x 5 矩形,然后使用RectangleArea.area方法显示矩形区域。

但是,您不能假设下载和使用您的 applet 的每个人都将在其系统上提供RectangleArea类,作为已安装的扩展或其他方式。解决该问题的一种方法是使RectangleArea类可以从服务器端获得,并且可以通过将其用作下载扩展来实现。

为了了解它是如何完成的,我们假设您已将AreaApplet捆绑在名为AreaApplet.jar的 JAR 文件中,并且类RectangleArea捆绑在RectangleArea.jar 中。为了将RectangleArea.jar视为下载扩展, RectangleArea.jar必须列在AreaApplet 的Class-Path标题中。 jar的清单。 AreaApplet.jar的清单可能如下所示,例如:

  1. Manifest-Version: 1.0
  2. Class-Path: RectangleArea.jar

此清单中Class-Path标头的值为RectangleArea.jar ,未指定路径,表示RectangleArea.jar位于同一目录中 applet 的 JAR 文件。

有关类路径标头的更多信息

如果 applet 或应用程序使用多个扩展名,您可以在清单中列出多个 URL。例如,以下是有效的标头:

  1. Class-Path: area.jar servlet.jar images/

Class-Path标题中,列出的所有未以’ / ‘结尾的 URL 都是 JAR 文件。以“ / ”结尾的网址表示目录。在前面的示例中, images /可能是包含 applet 或应用程序所需资源的目录。

请注意,清单文件中只允许一个Class-Path标头,并且清单中的每一行长度不得超过 72 个字符。如果需要指定多于适合一行的类路径条目,则可以将它们扩展到后续的连续行。以两个空格开始每个延续线。例如:

  1. Class-Path: area.jar servlet.jar monitor.jar datasource.jar
  2. provider.jar gui.jar

未来版本可以消除仅具有每个标题的一个实例的限制,并且限制行仅限于 72 个字符。

下载扩展名可以是“菊花链”,这意味着一个下载扩展名的清单可以有一个Class-Path标题,引用第二个扩展名,可以引用第三个扩展名,依此类推。

安装下载扩展

在上面的示例中,applet 下载的扩展只有在加载 applet 的浏览器仍在运行时才可用。但是,如果小程序和扩展程序的清单中包含其他信息,则小程序可以触发扩展程序的安装。

由于此机制扩展了平台的核心 API,因此应明智地应用它。它很少适用于单个或一小组应用程序使用的接口。所有可见符号应遵循反向域名和类层次结构约定。

基本要求是 applet 和它使用的扩展都在其清单中提供版本信息,并且它们是签名的。版本信息允许 Java Plug-in 确保扩展代码具有 applet 期望的版本。例如, AreaApplet可以在其清单中指定最新扩展名:

  1. Manifest-Version: 1.0
  2. Extension-List: areatest
  3. areatest-Extension-Name: area
  4. areatest-Specification-Version: 1.1
  5. areatest-Implementation-Version: 1.1.2
  6. areatest-Implementation-Vendor-Id: com.example
  7. areatest-Implementation-URL: http://www.example.com/test/area.jar

area.jar中的清单将提供相应的信息:

  1. Manifest-Version: 1.0
  2. Extension-Name: area
  3. Specification-Vendor: Example Tech, Inc
  4. Specification-Version: 1.1
  5. Implementation-Vendor-Id: com.example
  6. Implementation-Vendor: Example Tech, Inc
  7. Implementation-Version: 1.1.2

applet 和扩展名都必须由同一个签名者签名。签署 jar 文件将就地修改它们,在其清单文件中提供更多信息。签名有助于确保只安装受信任的代码。签名 jar 文件的一种简单方法是首先创建一个密钥库,然后使用它来保存 applet 和扩展的证书。例如:

  1. keytool -genkey -dname "cn=Fred" -alias test -validity 180

系统将提示您输入密钥库和密钥密码。生成密钥后,可以对 jar 文件进行签名:

  1. jarsigner AreaApplet.jar test
  2. jarsigner area.jar test

系统将提示您输入密钥库和密钥密码。有关keytooljarsigner和其他安全工具的更多信息,请参见 Java 2 平台安全工具摘要

这是AreaDemo.html ,它加载 applet 并导致下载和安装扩展代码:

  1. <html>
  2. <body>
  3. <applet code="AreaApplet.class" archive="AreaApplet.jar"/>
  4. </body>
  5. </html>

首次加载页面时,会告知用户 applet 需要安装扩展程序。随后的对话框会通知用户签名的 applet。接受两者都会在 JRE 的lib / ext文件夹中安装扩展并运行 applet。

重新启动 Web 浏览器并加载相同的网页后,仅显示有关小程序签名者的对话框,因为已安装area.jar 。如果在不同的 Web 浏览器中打开AreaDemo.html (假设两个浏览器使用相同的 JRE),也是如此。