使用Java Web Start部署基于Eclipse的应用程序

在你开始前

关于本教程

当我开始构建应用程序时,我选择了Java编程语言作为实现语言。 我想编写一个可以在Microsoft®Windows®,Linux®或Mac OS X上运行的应用程序。该应用程序必须使用本地资源,因此将其构建为独立的应用程序比在Web上尝试更有意义。应用。 但是,我在部署上陷入了困境。 我希望能够轻松地为初始安装部署应用程序,并且希望能够轻松地推送更新而不必在我的应用程序中构建更新框架。 输入JWS,这项技术可让您单击一下即可通过Internet部署应用程序。

如果您将JWS与在Eclipse平台上构建应用程序的能力结合在一起,那么您将拥有一个非常强大的组合,该组合使您能够以比构建和推出安装程序容易得多的方式部署一些重要的企业级工具。

本教程显示了如何基于Eclipse平台构建应用程序以及如何使用JWS部署该应用程序。 这不是与建设使用标准部件工具包(SWT)在Eclipse富客户端平台(RCP)应用,并使用JWS分发(见混淆相关信息 ,了解如何做到这一点的教程)。

目标

阅读完本教程之后,您应该能够开发一个扩展Eclipse平台的产品,并使用JWS部署基于Eclipse的应用程序。

先决条件

您应该熟悉Eclipse和Java编程语言。 阅读XML示例时,对XML的了解会有所帮助。

系统要求

要运行样本,您必须安装并运行Eclipse V3.3或更高版本。 您还需要安装Java V1.5或更高版本。 要运行JWS示例,您需要访问运行中的Web服务器,并具有将MIME类型关联添加到Web服务器(如果尚未正确配置)的能力。 理想情况下,您应该具有可用于测试的本地开发Web服务器。

Eclipse框架概述

Eclipse Java集成开发环境(IDE)构建在Eclipse平台上。 大多数人习惯使用的默认Java IDE是带有一组基本插件的标准Eclipse平台,这些插件随可下载的Eclipse发行版一起自动安装。 这些插件构成了用户作为IDE的体验。

从Eclipse站点,您可以仅下载Eclipse Platform软件开发工具包(SDK)。 仅使用Eclipse Platform SDK,如果不安装其他插件就无法进行Java开发。 如果尝试使用向导创建新项目,则会看到没有任何常用的向导(例如Java Project)可用。 由于行为有限,Eclipse Platform SDK本身并不是特别有用。 但是,由于Eclipse Platform SDK提供了用于构建应用程序的框架,因此作为构建更强大工具的起点非常有用。

当您在Eclipse平台上构建功能并拥有自己的应用程序时,下一步就是将其部署到用户。 JWS是可用于部署Java应用程序的机制。 用Java语言编写的Eclipse也不例外。 当用户单击链接时,JWS使您能够相对容易地通过Internet部署应用程序。

RCP应用

Eclipse还使您能够使用SWT构建RCP应用程序。 此过程不同于构建成为基于Eclipse平台的应用程序的产品。 使用SWT构建的应用程序可以较小,并且不需要扩展Eclipse平台。 如果您要构建的应用程序不扩展Eclipse平台,请考虑使用SWT。 您仍然可以使用JWS分发SWT应用程序。

Java Web Start概述

通过JWS,您只需单击一下即可在Internet上部署独立的Java应用程序。 您的用户单击指向带有Java网络启动协议(.jnlp)扩展名的XML文件的链接,其余的工作由JWS完成。 JWS使用JNLP下载所需的文件,将其缓存并启动应用程序。

作为开发人员,您将必要的文件(例如Java存档(JAR))放在可以从Web服务器访问的位置。 JNLP文件包含的信息告诉用户计算机上的JWS客户端从何处获取JAR。 因此,您不必将独立的Java应用程序部署到所有用户的计算机上,而只需将应用程序部署到Web服务器上。 您的用户从那里获取它。

除了部署之外,JWS还大大简化了更新。 每当启动JWS应用程序时,用户计算机上的JWS客户端都会尝试查找服务器,并确保客户端具有最新文件。 如果本地文件已过期,它将自动将更新的文件下载到客户端。 更新对用户几乎是透明的,这提供了理想的环境,通过该环境可以基于Eclipse平台部署应用程序。

安全

应用程序通常要求用户具有提升的权限才能安装它们。 用户拥有比通常更高级别的权限的需求通常成为提供用户在其计算机上安装应用程序能力的障碍,尤其是在大型公司中。 由于JWS将JAR缓存在非系统目录中并具有其他安全权限,因此用户无需具有提升的权限就可以在本地安装和运行JWS应用程序。 相对受限的用户能够利用JWS的能力是考虑将其部署在大型组织中的另一个令人信服的理由。

JWS以类似于Java小程序的“沙盒”执行方式运行应用程序。 JNLP文件中的条目(稍后将详细介绍)提供了请求访问文件系统和网络权限的能力。 要请求所有权限,必须签署JAR。 如果您有一个密钥库,Eclipse会为您解决这一问题。 (“打包应用程序”部分提供了有关配置Eclipse以使用您的密钥库的更多信息。)

离线运行

当用户下载了该应用程序并运行了一次之后,并且JWS在其本地缓存中拥有了所需的资源时,您的用户可以自由使用该应用程序而无需连接到Internet(只要您的应用程序不需要Internet)连接性)。 JWS仅使用本地缓存的资源来运行应用程序。

配置

安装JWS

如果您具有Java平台标准版(Java SE)V5或更高版本,则您已经安装了JWS。 如果您使用Windows,则会在Java主目录中安装JWS(例如,C:\ Program Files \ Java \ jre \ bin)。 在Mac OS X上,JWS驻留在Applications / Utilities / Java中。 您可以在不实际安装或运行JWS应用程序的情况下启动JWS控制台。

通过启动JWS控制台,您可以查看JWS缓存中的应用程序。 在控制台中,您可以启动已安装的任何JWS应用程序,将它们从缓存中删除,或安装应用程序的快捷方式。 要启动控制台,请输入以下命令,确保路径中包含Java

javaws -viewer

启动后,查看器将如图1所示。如果您以前从未使用过JWS,则可能没有安装任何应用程序。

图1. Java Web Start查看器
使用Java Web Start部署基于Eclipse的应用程序_第1张图片

如果没有安装Java Runtime Environment(JRE),请下载并安装最新版本。 只要是Java SE V5或更高版本,它将包含JWS。

配置您的Web服务器

在大多数情况下,如果打开JNLP文件,JWS应该自动启动。 如果JNLP文件位于未正确关联JNLP文件的Web服务器上,则可以下载该文件并在本地打开它。 实际上,我之前已经通过电子邮件发送了JNLP文件-仍然具有位于文件URL中的资源-收件人能够使用JWS成功运行该应用程序。

如果要设置Web服务器来提供JNLP文件(这是最简单的分发方法),则需要添加以下文件关联:

application/x-java-jnlp-file JNLP

请遵循Web服务器的文档以正确设置MIME关联。 如果使用的是ISP,请查阅ISP的文档以了解如何添加JNLP MIME类型。

JNLP文件结构

JNLP文件是一个XML文件,其中包含有关JWS如何下载和使用您的应用程序的说明。 它有助于理解JNLP文件的不同部分,因此您可以放心地对其进行修改。

清单1显示了一个基本的JNLP文件。 它仅具有通过JWS分发独立应用程序绝对必需的那些元素。

清单1.一个基本的JNLP文件


  
    Application Title
    Application Vendor
    
    This is an application.
  
  
    
  
  
  
  
  
    
  

清单1中的示例将告诉JWS从URL下载exampleApp.jar文件。 完整的URL为http://www.example.com/applications/exampleApp.jar。 下载JAR时,JWS将执行com.example.MyMainClass类。 假设该类需要运行的所有内容都包含在exampleApp.jar中,则它将在用户自己初始化它时运行。 该文件等同于运行命令:

java -cp exampleApp.jar com.example.MyMainClass

在此示例中,由于存在元素,因此必须对exampleApp.jar进行签名。

元素是文件的根元素,具有表1中的属性。

表1. 元素属性
属性 描述
spec 此文件将使用的JNLP规范的最低版本
codebase 应用程序的基本URL(文件中的其他URL将相对于该基本URL)
href JNLP文件本身的URL(JNLP文件可以脱机使用,并且此URL告诉JWS从何处获取在线版本)
version 应用程序的版本和JNLP文件(在构建JWS应用程序时,将它们视为同一件事)

元素具有表2中所示的属性。

表2. 元素的属性
属性 描述
os JWS应用程序支持的操作系统
arch 支持的架构(处理器)
platform 支持平台
locale 支持的语言环境

其他必需元素:

  • </code>元素包含应用程序的标题。</span> <span>这显示在JWS控制面板中。</span> <span>当用户使用JWS启动应用程序时,也会显示它。</span> </li> <li> <span><code><vendor></code>元素包含应用程序的软件供应商的名称。</span> </li> <li> <span><code><resources></code>元素包含有关应用程序所需资源的信息。</span> <span>这里的资源包括JAR,这些JAR包含应用程序使用的类或应用程序可以设置和使用的属性。</span> <span>典型的资源可以在表3中示出的元件中的任一个中列出(参见相关信息为一个完整的列表)。</span> </li> </ul> <h5 id="table3" class="ibm-h5"> <span>表3.典型的<code><resource></code>元素</span> </h5> <table border="0" class="ibm-data-table" summary="" width=""> <thead> <tr> <th class="ibm-background-neutral-white-30"> <span>元件</span> </th> <th class="ibm-background-neutral-white-30"> <span>描述</span> </th> </tr> </thead> <tbody> <tr> <td> <code><jar></code> </td> <td> <span>包含JAR的<code>href</code>的<code>href</code>属性</span> </td> </tr> <tr> <td> <code><nativelib></code> </td> <td> <span>包含对本机库JAR的<code>href</code>的<code>href</code>属性</span> </td> </tr> <tr> <td> <code><j2se></code> </td> <td> <span>赋予虚拟机(VM)的版本和参数</span> </td> </tr> <tr> <td> <code><property></code> </td> <td> <span>指定<code>System.getProperty</code>可以找到的属性</span> </td> </tr> </tbody> </table> <p> <span>有关JNLP文件的完整语法,请参见参考资料中的指向Sun Microsystems文档的链接 。</span> </p> <h2 id="N1038A" class="ibm-h2"> <span style="font-weight: bold;">构建一个基于Eclipse的基本应用程序</span> </h2> <p> <span>此时,您应该了解JNLP文件的功能以及它包含的内容,以便使用JWS部署应用程序。</span> <span>您应该具有一个Web服务器,可以从该服务器启动具有正确关联的JNLP文件。</span> <span>基本了解JWS和JNLP文件之后,您就可以开始基于Eclipse构建应用程序了。</span> </p> <h3 id="installeclipse" class="ibm-h3"> <span style="font-weight: bold;">安装Eclipse</span> </h3> <p> <span>首先,您需要下载Eclipse Platform SDK(如果尚未安装Eclipse)。</span> <span>如果您已经具有Eclipse,则可以使用已安装的版本。</span> <span>使用Platform SDK时,需要安装Eclipse Plug-in Development Environment功能(有关在安装程序中选择的功能的示例,请参见图2)。</span> <span>要了解有关在Eclipse中安装插件的更多信息,请参阅参考资料 。</span> </p> <h5 id="fig2" class="ibm-h5"> <span>图2.选择Eclipse插件开发环境</span> </h5> <div class="img-center" style="display:block;text-align:center;"> <a href="http://img.e-com-net.com/image/info8/578d7d48fd524a1bbd6b9642b8238a8b.jpg" target="_blank"><img src="http://img.e-com-net.com/image/info8/578d7d48fd524a1bbd6b9642b8238a8b.jpg" class="ibm-downsize" alt="使用Java Web Start部署基于Eclipse的应用程序_第2张图片" height="336" width="477" style="border:1px solid black;"></a> </div> <h3 id="createnewproduct" class="ibm-h3"> <span style="font-weight: bold;">创建一个新产品</span> </h3> <div class="dw-article-sidebar ibm-background-cool-white-20"> <h5> <span>检查一个例子</span> </h5> <p> <span>要查看Eclipse中的示例,请查看示例Web浏览器。</span> <span>该代码可通过并发版本系统(CVS)获得,因此要获取它,您的计算机上必须具有CVS客户端。</span> <span>您可以使用以下命令检出项目: <code>cvs -d :pserver:anonymous@dev.eclipse.org:/cvsroot/eclipse export -r HEAD org.eclipse.ui.examples.rcp.browser</code> 。</span> <span>在本地拥有项目后,可以将其导入到Eclipse工作区中。</span> </p> </div> <p> <span>要了解实际使用的JWS部署,请创建一个新产品。</span> <span>您的产品将包含一个将在Eclipse启动器启动Eclipse平台时自动加载的应用程序。</span> </p> <p> <span>该应用程序有一个简单的视图,向您显示已正确加载,类似于典型的Hello World应用程序。</span> <span>该视图在工作台中以新的视角打开。</span> <span>这些类的统一建模语言(UML)图如图3所示。</span> </p> <h5 id="fig3" class="ibm-h5"> <span>图3.产品基本类的UML</span> </h5> <div class="img-center" style="display:block;text-align:center;"> <a href="http://img.e-com-net.com/image/info8/5674cfba01144249ac02694bbe1d2981.gif" target="_blank"><img src="http://img.e-com-net.com/image/info8/5674cfba01144249ac02694bbe1d2981.gif" class="ibm-downsize" alt="使用Java Web Start部署基于Eclipse的应用程序_第3张图片" height="308" width="483" style="border:1px solid black;"></a> </div> <p> <span>为简洁起见,我使类尽可能简单。</span> <span>它们足以表明正在使用其自己的自定义视图加载新的自定义产品。</span> <span>如果您构建自己的产品,则可以添加菜单栏,其他视图,帮助屏幕等。</span> <span>要添加这些定制功能,请查看“ 相关主题”部分,以找到更多有关扩展Eclipse的地方。</span> </p> <p> <span>要构建一个简单的产品示例,请首先构建一个新的插件项目。</span> <span>选择“ <strong>文件”>“新建”>“项目”</strong> 。</span> <span>在<strong>Select a wizard</strong>窗口中,展开<strong>Plug-in Development</strong> ,然后选择<strong>Plug-in Project</strong> ,如图4所示。单击<strong>Next</strong>继续。</span> </p> <h5 id="fig4" class="ibm-h5"> <span>图4.选择插件项目</span> </h5> <div class="img-center" style="display:block;text-align:center;"> <a href="http://img.e-com-net.com/image/info8/4fa76d4de3004ad3bd01b0d70f09f185.jpg" target="_blank"><img src="http://img.e-com-net.com/image/info8/4fa76d4de3004ad3bd01b0d70f09f185.jpg" class="ibm-downsize" alt="使用Java Web Start部署基于Eclipse的应用程序_第4张图片" height="472" width="380" style="border:1px solid black;"></a> </div> <p> <span>对于<strong>项目名称</strong> ,输入适合您的项目的名称。</span> <span>我喜欢将插件的基本软件包名称用作项目,例如com.nathanagood.examples.rcp.simpleApp。</span> <span>Eclipse的插件项目似乎以相同的方式命名,因此我遵循该约定。</span> <span>输入项目名称后,将其他值保留为默认值。</span> </p> <h5 id="fig5" class="ibm-h5"> <span>图5.输入项目信息</span> </h5> <div class="img-center" style="display:block;text-align:center;"> <a href="http://img.e-com-net.com/image/info8/3bb34a6c0239473aad1b9fc72759819f.jpg" target="_blank"><img src="http://img.e-com-net.com/image/info8/3bb34a6c0239473aad1b9fc72759819f.jpg" class="ibm-downsize" alt="使用Java Web Start部署基于Eclipse的应用程序_第5张图片" height="475" width="382" style="border:1px solid black;"></a> </div> <p> <span>在<strong>Plug-in Content</strong>窗口(参见图6)中,您可以调整插件的名称,提供程序的名称和版本。</span> <span>我将.plugin添加到插件ID的默认值的末尾,但只是作为首选项。</span> <span>无需更改。</span> <span>如果要更改<code>Activator</code>类的名称或类的包,请在此窗口中进行更改。</span> <span>完成更改后,点击<strong>下一步</strong> 。</span> </p> <h5 id="fig6" class="ibm-h5"> <span>图6.输入插件内容</span> </h5> <div class="img-center" style="display:block;text-align:center;"> <a href="http://img.e-com-net.com/image/info8/8b4659d7368146b8bb422eb1cd5a3765.jpg" target="_blank"><img src="http://img.e-com-net.com/image/info8/8b4659d7368146b8bb422eb1cd5a3765.jpg" class="ibm-downsize" alt="使用Java Web Start部署基于Eclipse的应用程序_第6张图片" height="474" width="382" style="border:1px solid black;"></a> </div> <p> <span>“ <strong>模板”</strong>页面(请参见图7)包含一个模板列表,可以帮助您开始使用插件。</span> <span>因为我想创建一个示例视图,然后向其添加产品和应用程序扩展,所以我选择<strong>了带有视图的插件</strong>以开始使用。</span> <span>选择您要使用的模板,然后单击<strong>完成</strong>以构建您的项目。</span> </p> <h5 id="fig7" class="ibm-h5"> <span>图7.选择一个模板</span> </h5> <div class="img-center" style="display:block;text-align:center;"> <a href="http://img.e-com-net.com/image/info8/78ba86c5d11547119ade58cfcfe08959.jpg" target="_blank"><img src="http://img.e-com-net.com/image/info8/78ba86c5d11547119ade58cfcfe08959.jpg" class="ibm-downsize" alt="使用Java Web Start部署基于Eclipse的应用程序_第7张图片" height="474" width="380" style="border:1px solid black;"></a> </div> <h3 id="completeproject" class="ibm-h3"> <span style="font-weight: bold;">完成样例项目</span> </h3> <p> <span>此时,您将拥有一个带有视图的新插件项目。</span> <span>要完成示例项目的构建:</span> </p> <ol> <li> <span>扩展<code>WorkbenchAdvisor</code>类(在本示例中为<code>SimpleApplicationAdvisor</code> )。</span> <p> <span>此类具有一个返回透视图ID的方法,以在应用程序的初始化中加载透视图的ID,因此您可以立即看到带有自定义视图的自定义透视图,而无需看到Welcome工作台。</span> </p> </li> <li> <span>创建的实现<code>IPerspectiveFactory</code> (即<code>SimpleAppPerspectiveFactory</code> )。</span> <p> <span>工厂通过修改传递给其<code>createInitialLayout()</code>方法的<code>IPageLayout</code>来创建您的初始透视图。</span> </p> </li> <li> <span>扩展<code>WorkbenchWindowAdvisor</code> (即<code>SimpleWindowAdvisor</code> )。</span> <p> <span>通过覆盖<code>preWindowOpen()</code> ,可以设置工作台的初始大小和其他属性。</span> </p> </li> <li> <span>创建的实现<code>IApplication</code> (即<code>SimpleApplication</code> )。</span> <p> <span>实现类创建并运行您的自定义工作台配置,并在启动时加载您的透视图和视图。</span> </p> </li> </ol> <p> <span>这些类的示例在本教程随附的代码下载中提供。</span> </p> <h3 id="modifyplugin" class="ibm-h3"> <span style="font-weight: bold;">修改plugin.xml文件</span> </h3> <p> <span>构建完类之后,修改plugin.xml文件以包括扩展点,这些扩展点具有对刚创建的所有类的引用。</span> <span>像本教程一样,首先编写所有类的优点是,可以使用plugin.xml文件的图形编辑器来选择扩展点和类。</span> <span>尽管您也可以轻松地手动编辑源XML,但是使用GUI添加扩展点可以减少类名或扩展点输入错误的可能性。</span> <span>我的大部分疑难解答都导致了复制和粘贴错误,其中我错误输入了ID或类名。</span> </p> <p> <span>图8在图形化的插件清单编辑器的<strong>Extensions</strong>选项卡上显示了扩展点。</span> </p> <h5 id="fig8" class="ibm-h5"> <span>图8.扩展点</span> </h5> <div class="img-center" style="display:block;text-align:center;"> <a href="http://img.e-com-net.com/image/info8/fad8430054dd413183d47943458c0afc.jpg" target="_blank"><img src="http://img.e-com-net.com/image/info8/fad8430054dd413183d47943458c0afc.jpg" class="ibm-downsize" alt="使用Java Web Start部署基于Eclipse的应用程序_第8张图片" height="314" width="500" style="border:1px solid black;"></a> </div> <p> <span>清单2显示了plugin.xml文件的示例。</span> </p> <h5 id="list2" class="ibm-h5"> <span>清单2.示例plugin.xml文件</span> </h5> <pre class="has"><code class="notranslate brush: js; html-script: true; gutter: true;"><?xml version="1.0" encoding="utf-8"?> <?eclipse version="3.2"?> <plugin> <extension point="org.eclipse.ui.views"> <category name="Sample Category" id="com.nathanagood.examples.rcp.simpleApp.plugin"></category> <view name="Sample View" icon="icons/sample.gif" category="com.nathanagood.examples.rcp.simpleApp.plugin" class="com.nathanagood.examples.rcp.simpleapp.plugin.views.SampleView" id="com.nathanagood.examples.rcp.simpleapp.plugin.views.SampleView"> </view> </extension> <extension point="org.eclipse.ui.perspectives"> <perspective id="com.nathanagood.examples.rcp.simpleApp.plugin.perspective" name="Simple App Perspective" class="com.nathanagood.examples.rcp.simpleapp.SimpleAppPerspectiveFactory" fixed="false" /> </extension> <extension point="org.eclipse.ui.perspectiveExtensions"> <perspectiveExtension targetID="org.eclipse.jdt.ui.JavaPerspective"> <view ratio="0.5" relative="org.eclipse.ui.views.TaskList" relationship="right" id="com.nathanagood.examples.rcp.simpleapp.plugin.views.SampleView"> </view> </perspectiveExtension> </extension> <extension point="org.eclipse.help.contexts"> <contexts file="contexts.xml"></contexts> </extension> <extension point="org.eclipse.core.runtime.products" id="product"> <product name="Simple App" application="com.nathanagood.examples.rcp.simpleApp.plugin.app"> <property name="appName" value="Simple App" /> </product> </extension> <extension id="app" point="org.eclipse.core.runtime.applications"> <application> <run class="com.nathanagood.examples.rcp.simpleapp.SimpleApplication"> </run> </application> </extension> </plugin></code></pre> <h3 id="addconfigfile" class="ibm-h3"> <span style="font-weight: bold;">添加配置文件</span> </h3> <p> <span>在完全修改并保存了plugin.xml文件之后,是时候添加用于向Eclipse平台介绍您的产品的产品配置文件了:</span> </p> <ol> <li> <span>选择“ <strong>文件”>“新建”>“产品配置”</strong> 。</span> <p> <span>出现“ <strong>产品配置”</strong>窗口。</span> </p> <h5 id="fig9" class="ibm-h5"> <span>图9.产品配置</span> </h5> <div class="img-center" style="text-align: center;"> <a href="http://img.e-com-net.com/image/info8/0654b647c87b473d8412ede0e15d7a78.jpg" target="_blank"><img src="http://img.e-com-net.com/image/info8/0654b647c87b473d8412ede0e15d7a78.jpg" class="ibm-downsize" alt="使用Java Web Start部署基于Eclipse的应用程序_第9张图片" height="478" width="397" style="border:1px solid black;"></a> </div></li> <li> <span>选择您的插件项目作为父文件夹。</span> </li> <li> <span>添加文件名(例如<code>SimpleApplication.product</code> )。</span> </li> <li> <span>选择<strong>使用现有产品</strong> ,然后从列表中选择产品的ID。</span> <p> <span>产品的ID是您在<code>org.eclipse.core.runtime.products</code>扩展点下的plugin.xml文件中定义的。</span> </p> </li> </ol> <p> <span>添加产品配置文件后,可以使用图形产品配置编辑器来编辑有关产品的详细信息。</span> <span>在<strong>概述</strong>选项卡上,单击<strong>同步</strong>以确保您的配置是最新的。</span> <span>现在,您可以单击“ <strong>启动Eclipse应用程序”</strong> (参见图10)以测试您的产品。</span> <span>如果您需要对其进行调试,请单击“ <strong>以调试模式启动Eclipse应用程序”</strong> 。</span> </p> <h5 id="fig10" class="ibm-h5"> <span>图10.启动Eclipse应用程序</span> </h5> <div class="img-center" style="display:block;text-align:center;"> <a href="http://img.e-com-net.com/image/info8/53ece89fb84c4a3aa65efe2aa2ded228.jpg" target="_blank"><img src="http://img.e-com-net.com/image/info8/53ece89fb84c4a3aa65efe2aa2ded228.jpg" class="ibm-downsize" alt="使用Java Web Start部署基于Eclipse的应用程序_第10张图片" height="185" width="500" style="border:1px solid black;"></a> </div> <h3 id="runproduct" class="ibm-h3"> <span style="font-weight: bold;">运行您的产品</span> </h3> <p> <span>在继续之前,请确保您可以成功运行产品。</span> <span>现在,确保它运行正常,可以消除沮丧和以后的故障排除。</span> <span>启动后,代码下载如图11所示。</span> </p> <h5 id="fig11" class="ibm-h5"> <span>图11.简单的示例应用程序</span> </h5> <div class="img-center" style="display:block;text-align:center;"> <a href="http://img.e-com-net.com/image/info8/647ef0f5083c41e5908d2df47bbd3174.jpg" target="_blank"><img src="http://img.e-com-net.com/image/info8/647ef0f5083c41e5908d2df47bbd3174.jpg" class="ibm-downsize" alt="使用Java Web Start部署基于Eclipse的应用程序_第11张图片" height="364" width="482" style="border:1px solid black;"></a> </div> <h2 id="packageapp" class="ibm-h2"> <span style="font-weight: bold;">打包应用程序</span> </h2> <p> <span>至此,您应该对JWS和JNLP文件结构有基本的了解。</span> <span>您应该具有一个Web服务器,可以在其上发布产品的文件和JNLP文件,并且应该具有可以从Eclipse IDE启动的工作产品。</span> <span>完成所有这些操作后,您就可以构建包装器功能了,该功能将用于发布产品。</span> </p> <h3 id="createwrapper" class="ibm-h3"> <span style="font-weight: bold;">创建包装器功能</span> </h3> <p> <span>包装功能只是一个功能项目,其中包含两个文件,每个文件都包含对产品插件以及运行产品插件所需的任何必要插件和功能的引用。</span> <span>要添加新包装器功能项目,请选择“ <strong>文件”>“新建”>“项目”</strong> 。</span> <span>然后在<strong>Select a Wizard</strong>窗口中,展开<strong>Plug-in Development</strong>并选择<strong>Feature Project</strong> ,如图12所示。</span> </p> <h5 id="fig12" class="ibm-h5"> <span>图12.创建一个新的功能项目</span> </h5> <div class="img-center" style="display:block;text-align:center;"> <a href="http://img.e-com-net.com/image/info8/3f44af6c6bc34440aed04f8cb0622e92.jpg" target="_blank"><img src="http://img.e-com-net.com/image/info8/3f44af6c6bc34440aed04f8cb0622e92.jpg" class="ibm-downsize" alt="使用Java Web Start部署基于Eclipse的应用程序_第12张图片" height="445" width="465" style="border:1px solid black;"></a> </div> <p> <span>在<strong>Feature Properties</strong>窗口中,输入项目的名称,功能ID,名称,版本和提供者信息,如图13所示,然后单击<strong>Next</strong> 。</span> </p> <h5 id="fig13" class="ibm-h5"> <span>图13.编辑特征属性</span> </h5> <div class="img-center" style="display:block;text-align:center;"> <a href="http://img.e-com-net.com/image/info8/194a49b0a4e44873bb92f21b70df561f.jpg" target="_blank"><img src="http://img.e-com-net.com/image/info8/194a49b0a4e44873bb92f21b70df561f.jpg" class="ibm-downsize" alt="使用Java Web Start部署基于Eclipse的应用程序_第13张图片" height="470" width="435" style="border:1px solid black;"></a> </div> <p> <span>在“ <strong>参考的插件和片段”</strong>窗口中,如图14所示, <strong>从启动配置中</strong>选择<strong>Initialize</strong> ,然后从列表中选择产品的配置文件的名称(例如SimpleApp.product )。</span> <span><strong>完成后</strong> ,单击“ <strong>完成”</strong> 。</span> </p> <h5 id="fig14" class="ibm-h5"> <span>图14.选择产品配置</span> </h5> <div class="img-center" style="display:block;text-align:center;"> <a href="http://img.e-com-net.com/image/info8/f44eaa40564b4185b6140379dd93796a.jpg" target="_blank"><img src="http://img.e-com-net.com/image/info8/f44eaa40564b4185b6140379dd93796a.jpg" class="ibm-downsize" alt="使用Java Web Start部署基于Eclipse的应用程序_第14张图片" height="470" width="436" style="border:1px solid black;"></a> </div> <div class="dw-article-sidebar ibm-background-cool-white-20"> <h5 id="sidebar"> <span>创建密钥库</span> </h5> <p> <span>要通过JWS部署插件和功能,必须对JAR进行签名。</span> <span>签名JAR需要一个密钥库,您可以使用Java软件开发工具包(JDK)随附的Java密钥工具生成该密钥库。</span> <span>有关创建密钥库的更多信息,请参阅参考资料 。</span> </p> </div> <p> <span>新的功能项目将有两个文件:build.properties和feature.xml。</span> <span>feature.xml文件具有图形编辑器,例如图形产品配置和插件编辑器。</span> <span>打开feature.xml文件的图形编辑器。</span> </p> <p> <span>在“ <strong>插件”</strong>选项卡上,确保列出了您的产品插件。</span> <span>另外,请验证是否列出了<code>org.eclipse.equinox.launcher</code>插件。</span> <span>在“ <strong>功能”</strong>选项卡上,包括您的插件或功能所需的所有其他功能。</span> <span>如果您急于使用JWS来查看您的产品,则可以选择所有这些产品。</span> <span>除了应用程序的目录大小外,它不会造成任何伤害。</span> <span>但是,对于实际产品,您应该跟踪依赖关系,以使下载大小尽可能地小巧。</span> </p> <h3 id="exportwrapper" class="ibm-h3"> <span style="font-weight: bold;">导出包装器功能</span> </h3> <p> <span>选择了插件和功能部件后,可以将功能部件包装程序项目导出到目录中。</span> <span>要导出项目,请选择“ <strong>文件”>“导出”</strong> 。</span> <span>在<strong>Select</strong>窗口中,展开<strong>Plug-in Development</strong> ,然后单击<strong>Deployable Features</strong> ,如图15所示。单击<strong>Next</strong> 。</span> </p> <h5 id="fig15" class="ibm-h5"> <span>图15.创建可部署的功能</span> </h5> <div class="img-center" style="display:block;text-align:center;"> <a href="http://img.e-com-net.com/image/info8/8b34031f0e714e4cb0b4502495a6486e.jpg" target="_blank"><img src="http://img.e-com-net.com/image/info8/8b34031f0e714e4cb0b4502495a6486e.jpg" class="ibm-downsize" alt="使用Java Web Start部署基于Eclipse的应用程序_第15张图片" height="468" width="447" style="border:1px solid black;"></a> </div> <p> <span>现在:</span> </p> <ol> <li> <span>在图16所示的<strong>Deployable features</strong>窗口中,选择您的功能。</span> <h5 id="fig16" class="ibm-h5"> <span>图16.选择要部署的功能</span> </h5> <div class="img-center" style="text-align: center;"> <a href="http://img.e-com-net.com/image/info8/8218b6d4aa0e4469aa6fb541ed237297.jpg" target="_blank"><img src="http://img.e-com-net.com/image/info8/8218b6d4aa0e4469aa6fb541ed237297.jpg" class="ibm-downsize" alt="使用Java Web Start部署基于Eclipse的应用程序_第16张图片" height="471" width="423" style="border:1px solid black;"></a> </div></li> <li> <span>在“ <strong>目标”</strong>选项卡上,单击“ <strong>目录”</strong> ,然后键入要将文件发布到的目录的名称。</span> <span>该目录应位于Web文件夹下,以便可以使用<strong>Java Web Start</strong>选项卡上提供的URL对其进行访问。</span> </li> <li> <span>在“ <strong>选项”选项</strong>卡上,选择“ <strong>打包为单个JAR存档”</strong> 。</span> </li> <li> <span>在“ <strong>JAR签名”</strong>选项卡上,选择<strong>“使用密钥库</strong> <strong>签名</strong> <strong>JAR归档文件”</strong> 。</span> <span>然后浏览到您的密钥库位置,然后输入别名和密码。</span> <p> <span><strong>注:</strong>如果您没有密钥库,请参阅相关信息 ,了解如何创建一个链接。</span> </p> </li> <li> <span>在<strong>Java Web Start</strong>选项卡上,选择<strong>创建JAR归档文件的JNLP清单</strong> 。</span> </li> <li> <span>将<strong>站点URL</strong>更新为JWS目录的基本URL。</span> <span>从浏览器访问此URL应该访问您在“ <strong>目标”</strong>选项卡上输入的目录。</span> <span>有关示例,请参见图1。</span> <h5 id="fig17" class="ibm-h5"> <span>图17.设置JWS属性</span> </h5> <div class="img-center" style="text-align: center;"> <a href="http://img.e-com-net.com/image/info8/bde8dcf34cd14e1eb38e1d0b7e858758.jpg" target="_blank"><img src="http://img.e-com-net.com/image/info8/bde8dcf34cd14e1eb38e1d0b7e858758.jpg" class="ibm-downsize" alt="使用Java Web Start部署基于Eclipse的应用程序_第17张图片" height="471" width="424" style="border:1px solid black;"></a> </div></li> </ol> <p> <span>更新完有关功能部署的信息后,请单击“ <strong>完成”</strong> 。</span> <span>Eclipse将信息导出到提供的目录中。</span> <span>根据所选的插件和功能的数量以及您的硬件资源,导出功能可能需要一些时间。</span> <span>Eclipse完成后,您将在提供的目录中有两个新目录:功能和插件。</span> <span>要素的JNLP文件将位于features目录中。</span> <span>有关features目录内容的清单示例,请参见清单3。</span> </p> <h5 id="list3" class="ibm-h5"> <span>清单3. features目录的内容</span> </h5> <pre class="has"><code class="notranslate brush: js; html-script: true; gutter: true;">$ ls com.nathanagood.examples.simpleApp.feature_1.0.0.jar com.nathanagood.examples.simpleApp.feature_1.0.0.jnlp org.eclipse.equinox.p2.user.ui.source_1.0.1.r34x_v20080721-7d-7OEMsLAz-vTBJ.jar org.eclipse.equinox.p2.user.ui.source_1.0.1.r34x_v20080721-7d-7OEMsLAz-vTBJ.jnlp org.eclipse.equinox.p2.user.ui_1.0.1.r34x_v20080721-7d-7OEMsLAz-vTBJ-ZHQaF155CE.jar org.eclipse.equinox.p2.user.ui_1.0.1.r34x_v20080721-7d-7OEMsLAz-vTBJ-ZHQaF155CE.jnlp org.eclipse.help.source_1.0.1.R34x_v20080827-7r7xEIxEI6Zu5nEqN7M3UBpglaat.jar org.eclipse.help.source_1.0.1.R34x_v20080827-7r7xEIxEI6Zu5nEqN7M3UBpglaat.jnlp org.eclipse.help_1.0.1.R34x_v20080827-7r7xEIxEI6Zu5nEqN7M3UBpglaat.jar org.eclipse.help_1.0.1.R34x_v20080827-7r7xEIxEI6Zu5nEqN7M3UBpglaat.jnlp org.eclipse.platform.source_3.4.1.r341_v20080731-9I96EiDElYevwz.jar org.eclipse.platform.source_3.4.1.r341_v20080731-9I96EiDElYevwz.jnlp org.eclipse.platform_3.4.1.r341_v20080731-9I96EiDElYevwz-p1bP5z-NlAaP7vtX6Utotqsu.jar org.eclipse.platform_3.4.1.r341_v20080731-9I96EiDElYevwz-p1bP5z-NlAaP7vtX6Utotqsu.jnlp org.eclipse.rcp.source_3.4.100.r341_v20080814-989JESIEdAciFYfkZZsBfSwQ2341.jar org.eclipse.rcp.source_3.4.100.r341_v20080814-989JESIEdAciFYfkZZsBfSwQ2341.jnlp org.eclipse.rcp_3.4.100.r341_v20080814-989JESIEdAciFYfkZZsBfSwQ2341.jar org.eclipse.rcp_3.4.100.r341_v20080814-989JESIEdAciFYfkZZsBfSwQ2341.jnlp</code></pre> <p> <span>通过将包装器功能成功导出到可从Web服务器访问的目录中,是时候构建应用程序的主JNLP文件了。</span> </p> <h2 id="N1066F" class="ibm-h2"> <span style="font-weight: bold;">JNLP文件</span> </h2> <p> <span>在本部分中,您将构建并发布JNLP文件,然后测试部署并执行可能需要的任何故障排除。</span> </p> <h3 id="buildjnlp" class="ibm-h3"> <span style="font-weight: bold;">生成JNLP文件</span> </h3> <p> <span>此时,您应该已经将功能部件成功导出到目录,并验证了功能部件和插件目录是否存在于可从Web服务器访问的位置。</span> <span>现在是时候为您的应用程序编写JNLP文件了。</span> <span>完整提供了一个示例JNLP文件。</span> </p> <h5 id="list4" class="ibm-h5"> <span>清单4.简单应用程序的示例JNLP文件</span> </h5> <pre class="has"><code class="notranslate brush: js; html-script: true; gutter: true;"><?xml version="1.0" encoding="utf-8"?> <jnlp spec="1.0+" codebase="http://localhost/~user/jws2" href="simpleapp.jnlp"> <information> <title>SimpleApp Test Nathan Good This is my simple JWS Eclipse application test.

    在此JNLP文件中, codebase属性的值设置为将包装器功能发布到的位置的基本URL。 它应该与您在图17的Deployable features窗口中的Java Web Start选项卡上使用的URL匹配href属性是JNLP文件的名称。

    元素包括标题,描述以及有关正在分发的应用程序的其他信息。 元素需要如清单4所示。

    修改元素,以为元素包括正确版本的Equinox启动器插件。 您可能必须在features目录中查找启动器的JAR的正确全名。 随着文件新版本的发布,清单4中的名称可能很快就会过时。

    更新元素的href属性,以包括包装器功能的JNLP文件的URL(相对于codebase属性中的URL)。 包装器功能的JNLP文件将包括所有其他必需的功能和插件。

    最后,更新元素以包括您产品的ID。 该ID将是插件产品配置文件(即SimpleApp.product )中的ID。

    发布JNLP文件

    至此,您已经构建了JNLP文件。 您具有导出可部署功能的功能和插件目录。 该功能包括您的插件以及所有依赖项。 您已经准备好发布JNLP文件。

    JNLP文件与features和plugins目录位于同一目录中。 它应该与导出可部署功能时使用的目录相同。 清单5显示了示例目录清单。

    清单5.带有JNLP文件的目录清单
    drwxr-xr-x   20 user  user   680 Dec 19 09:46 features
    drwxr-xr-x  280 user  user  9520 Dec 19 09:46 plugins
    -rw-r--r--    1 user  user  1222 Dec 19 10:05 simpleapp.jnlp

    为了便于测试文件,请创建一个简单HTML页面并将其命名为index.html。 它应该包括清单6中所示的代码,其中simpleapp.jnlp被更新为您的JNLP文件的名称。

    清单6.示例HTML文件
    
    
    
    My Application
    
    
    My Application
    
    

    将HTML文件保存在可从应用程序主JNLP文件中的代码库URL访问的文件夹中。 将HTML文件保存在目录中之后,目录清单应类似于清单7。

    清单7.所有文件的目录清单
    drwxr-xr-x   20 user  user   680 Dec 19 09:46 features
    -rw-r--r--    1 user  user   288 Dec 19 08:37 index.html
    drwxr-xr-x  280 user  user  9520 Dec 19 09:46 plugins
    -rw-r--r--    1 user  user  1222 Dec 19 10:05 simpleapp.jnlp

    测试部署

    此时,您:

    • 了解JNLP文件的基本结构。
    • 使用适当的MIME类型配置您的Web服务器。
    • 在插件项目中构建基本的Eclipse产品。
    • 有一个包含插件的包装器功能项目。
    • 将包装器功能导出到目录。
    • 为您的应用程序创建并保存了一个JNLP文件。

    现在该测试部署了。 打开Web浏览器,然后导航到为代码库URL提供的URL(例如,http:// localhost /〜user / jws /)。 您将在“发布JNLP文件”部分中创建的index.html文件出现。 点击链接。 如果一切都已正确配置,则应该显示JWS的初始屏幕(请参见图18)。 然后,出现下载应用程序的进度。 根据功能和插件的最终大小以及网络连接,此过程可能需要一些时间。

    图18. JWS初始屏幕
    使用Java Web Start部署基于Eclipse的应用程序_第18张图片

    下载所有依赖项后,将打开应用程序。 我的简单视图如图19所示。

    图19.从JWS开始的简单应用程序
    使用Java Web Start部署基于Eclipse的应用程序_第19张图片

    故障排除

    在构建通过JWS部署Eclipse产品的第一个示例时,我遇到了两个问题:

    • JNLP文件在浏览器中显示为文本。 如果发生这种情况,最可能的原因是Web服务器配置中的JNLP类型缺少MIME类型关联。 确保关联了正确的MIME类型(请参阅“配置Web服务器”部分)。
    • 无法启动应用程序。 如果从JWS收到此错误,请单击“ 详细信息”以获取有关该错误的更多信息。 如果错误是java.io.FileNotFoundException ,则可能是URL不正确。 重命名初始的JNLP文件时收到此错误,但忘记更新元素的href属性中的值。
    • 无法加载资源。 与上一个错误类似,单击“ 详细信息”后,此消息可见。 尝试在另一台计算机上测试应用程序时出现此错误。 在本示例的URL中,我使用localhost作为主机名。 要解决此问题,请将URL更改为要在其上发布JNLP文件的服务器的IP地址或主机名。
    • JWS似乎已启动,但看不到任何内容,并且JWS关闭。 造成此问题的最可能原因是元素中eclipse.product属性中的产品ID不正确。 仔细检查产品ID的值,并确保它与产品配置文件(SimpleApp.product)中的ID匹配。

    摘要

    本教程演示了如何构建一个简单的产品—一个基于Eclipse平台构建的应用程序—并使用JWS将其部署到您的用户。 通过执行此处的步骤并添加您自己的扩展,您可以构建可以从中央位置部署到许多平台的复杂应用程序。 更新就像将更新部署到部署JWS资源的目录一样容易。

    要成功构建产品,您需要对JNLP文件的结构有所了解。 您需要使用至少两个类的实现来构建一个插件。 您需要在插件中提供扩展点。 最后,您需要向插件项目中添加产品配置。

    插件项目完成后,您需要构建一个包装器功能,其中包括您的插件以及运行该插件所需的所有其他功能和插件。 完成包装器功能后,可以使用Eclipse向导将必要的文件部署到目录结构中。

    一个简单的JNLP文件包含对您创建的包装器功能的JNLP文件的引用。 它还包含使Eclipse运行产品所需的任何其他参数,例如启动产品ID。


    翻译自: https://www.ibm.com/developerworks/opensource/tutorials/os-eclipse-jws/index.html

你可能感兴趣的:(使用Java Web Start部署基于Eclipse的应用程序)