JavaFX本地应用自动更新功能的实现FXLauncher

简介: 版权声明:本文为博主chszs的原创文章,未经博主允许不得转载。 https://blog.csdn.net/chszs/article/details/50669923 JavaFX本地应用自动更新功能的实现——FXLauncher作者:chszs,未经博主允许不得转载。
版权声明:本文为博主chszs的原创文章,未经博主允许不得转载。 https://blog.csdn.net/chszs/article/details/50669923

JavaFX本地应用自动更新功能的实现——FXLauncher

作者:chszs,未经博主允许不得转载。经许可的转载需注明作者和博客主页:http://blog.csdn.net/chszs

一、Javapackager介绍

JavaFX已经成为构建现代桌面应用最好的UI框架之一,但是它一直存在部署不方便的问题。Javapackager工具就是针对这个问题的解决方案,正如同JavaFX已经打包进JDK 8中,Javapackager工具也随同JDK 8一同提供。
Javapackager工具使得创建本地应用的安装器很容易,但是很遗憾的是,Javapackager不支持自动更新。而Java Web Start倒是可以支持更新操作,但它不能打包本地应用。
Javapackager工具可以执行针对Java应用程序和JavaFX应用程序的打包和签名的任务。

语法: javapackager command [options]

command包括:
1)-createbss
转换CSS文件为二进制形式
2)-createjar
根据其它参数产生JAR文档
3)-deploy
产生基本的应用程序发布包(可以是自包含的应用程序发布包)
4)-makeall
执行编译,createjar和deploy都会调用它
5)-signjar
根据提供的证书对应用程序签名

二、FXLauncher介绍

FXLauncher工具结合了Javapackager的本地安装器功能和Java Web Start相似的更新机制,使得可以使用FXLauncher而无需本地安装包,以及发布仅有14KB的可运行JAR文件(launcher),通过在线安装方式下载应用的各个模块并保持应用的版本更新。

launcher会先查看应用程序的manifest文件(app.xml)的内容,manifest文件用于在启动时同步本地artifact。
当Manifest被载入时,用户会看到这样的动画:
这里写图片描述
当应用程序开始更新时,用户会看到这样的动画:
这里写图片描述
预载入器接着会控制应用程序的过程。launcher看起来是使用CSS配置的。

manifest文件(app.xml)的内容示例:

<Application uri="http://fxldemo.tornado.no/" launch="no.tornado.FxlDemo">
    <lib file="controlsfx.jar" checksum="1589854040" size="954085"/>
    <lib file="fxldemo-2.0.jar" checksum="223197943" size="4865"/>
    <updateText>Updating...</updateText>
    <updateLabelStyle>-fx-font-weight: bold;</updateLabelStyle>
    <progressBarStyle>-fx-pref-width: 200;</progressBarStyle>
    <wrapperStyle>-fx-spacing: 10; -fx-padding: 25;</wrapperStyle>
</Application>

本地安装器不包含任何代码,因此在应用程序发布新版本时无需重建它们,只需简单地复制应用程序的artifact到预定义的位置,FXLauncher会处理剩下的一切工作。

FXLauncher还可以处理多种编程语言的应用,它与TornadoFX结合起来工作的极好。
FXLauncher和Tornado结合的例子见: http://fxldemo.tornado.no/

三、FXLauncher的使用步骤

1)编译项目JAR到app.dir
2)复制依赖包到app.dir
3)生成app.xml manifest
4)创建本地安装器
5)上传artifact到自动更新仓库

复制部署描述符,并按自己的需求进行修改:

<properties>
    <!-- 应用程序名 -->
    <app.filename>${project.name}</app.filename>
    <!-- JavaFX应用的入口类 -->
    <app.mainClass>no.tornado.FxlDemo</app.mainClass>
    <!-- app和launcher存放位置 -->
    <app.dir>${project.build.directory}/app</app.dir>
    <!-- 本地安装器存放位置 -->
    <app.installerdir>${project.build.directory}/installer</app.installerdir>
    <!-- 托管应用artifact的基础URL -->
    <app.url>http://fxsamples.tornado.no/demo/</app.url>
    <!-- Optional scp target for application artifacts hosted at the above url -->
    <app.deploy.target>w48839@fxldemo.tornado.no:fxldemo</app.deploy.target>
</properties>

四、Maven目标

1、产生应用程序

mvn clean package

2、部署应用程序artifact到自己的Web服务器

mvn exec:exec@deploy-app

3、建立本地安装器

mvn exec:exec@installer

五、TornadoFX介绍

TornadoFX是针对Kotlin语言的轻量级JavaFX框架。TornadoFX的特性包括:
1)依赖注入
2)类型安全建立器
3)异步任务执行
4)MVC
5)极度轻量级
6)小巧简单的API
7)为模型对象提供的REST客户端
8)零配置,无需XML,无需注释

https://github.com/edvin/tornadofx

Tornado的Maven依赖:

<dependency>
    <groupId>no.tornado</groupId>
    <artifactId>fx</artifactId>
    <version>1.2.3</version>
</dependency>
目录
相关文章
|
1月前
|
iOS开发 UED
Flutter 动态修改应用图标功能指南
探索Flutter中动态应用图标的实现方法,了解如何为用户提供独特体验,促进用户升级和应用内购买。
Flutter 动态修改应用图标功能指南
|
Linux iOS开发 MacOS
Flutter桌面开发之窗口管理
今天跟着大家一起学习桌面开发之窗口管理,关于桌面窗口管理,我网上查了很久资料,我觉得window_manager 这个插件几乎可以满足市面上大部分需求了
Flutter桌面开发之窗口管理
|
3月前
|
Linux 开发者 iOS开发
Flutter笔记:桌面端应用多窗口管理方案
Flutter笔记:桌面端应用多窗口管理方案
119 0
|
4月前
|
Java C# Android开发
Xamarin.Android | 界面跳转到手机自带的自启动管理界面,引导用户将APP加入自启动
为了帮助用户在使用 APP 时提高其稳定性和使用体验,有时候我们需要让安卓手机的界面跳转到手机自带的自启动管理界面,以此来引导用户将 APP 加入自启动,确保应用程序在后台运行时不被系统杀死,从而保证应用程序服务的稳定性和可靠性。同时,这也可以提高用户的使用体验,使用户能够更好地享受应用程序的功能和服务。
100 0
Xamarin.Android | 界面跳转到手机自带的自启动管理界面,引导用户将APP加入自启动
|
7月前
|
资源调度
SAP Spartacus UI 服务器端渲染的调试启动方式 - debug 模式
SAP Spartacus UI 服务器端渲染的调试启动方式 - debug 模式
58 0
Flutter实时动态UI刷新、数据交互
Flutter实时动态UI刷新、数据交互
|
10月前
|
JavaScript 安全 Android开发
Android应用之Hybird混合开发,集成web页面的方法尝试
Android应用之Hybird混合开发,集成web页面的方法尝试
|
测试技术 iOS开发
Flutter Web网站之最简方式实现暗黑主题无缝切换
Flutter Web网站之最简方式实现暗黑主题无缝切换
268 0
Flutter Web网站之最简方式实现暗黑主题无缝切换
【Flutter】当项目中使用交互并且使用小工具管理其状态widget的state的详解
【Flutter】当项目中使用交互并且使用小工具管理其状态widget的state的详解
|
Web App开发 测试技术
Chrome-headless 模式,没有UI界面的自动化UI测试
Chrome-headless 模式,没有UI界面的自动化UI测试
Chrome-headless 模式,没有UI界面的自动化UI测试