侧边栏壁纸
博主头像
xuesheng博主等级

分享web知识,学习就是取悦自己!

  • 累计撰写 118 篇文章
  • 累计创建 14 个标签
  • 累计收到 3 条评论

目 录CONTENT

文章目录

【NWJS】解析node-webkit(NWJS)的打包和发布

xuesheng
2022-10-10 / 0 评论 / 0 点赞 / 228 阅读 / 1,416 字 / 正在检测是否收录...
温馨提示:
本文最后更新于 2022-10-10,若内容或图片失效,请留言反馈。部分素材来自网络,若不小心影响到您的利益,请联系我们删除。

node-webkit是一个Chromium和node.js上的结合体,通过它我们可以把建立在chrome浏览器和node.js上的web应用打包成桌面应用,而且还可以跨平台的哦。很显然比起传统的桌面应用,在某些特定领域用html5+css3+js开发的web应用更加简单和高效,而且还可以使用node.js的功能,所以node-webkit还是很有用处的。

node-webkit的官方网址:https://nwjs.io/
githup的访问地址:https://github.com/nwjs
node-webkit的中文网址:https://nwjs-cn.readthedocs.io/zh_CN/latest/

下载的时候有两个版本,一个是NORMAL版,另一个是SDK版本。SDK版本支持debug调试,NORMAL不支持。开发的话,应该下载SDK版本,发布的话应该下载NORMAL版本。

1.建立一个简单的WEB应用

新建立一个app/index.html,作为这个demo的入口文件:

<html>
<head>
    <meta charset="utf-8" />
    <title>Demo</title>
<head>
<body>
    <h1>Hello World!</h1>
</body>
<html>

创建一个配置文件package.json:

{
"main": "app/index.html",
"name": "nw-demo",
"description": "demo app of node-webkit",
"version": "0.1.0",
"keywords": [ "demo", "node-webkit" ],
"window": {
  "title": "node-webkit demo",
  "toolbar": true,
  "frame": true,
  "width": 800,
  "height": 500,
  "position": "center",
  "min_width": 400,
  "min_height": 200,
  "max_width": 800,
  "max_height": 600
},
"webkit": {
  "plugin": true
}
}

其中main属性用来指定入口文件,这个属性值可以是本地文件,也可以是远程网址(相当于把一个远程的web界面直接变成一个桌面应用了)。其它的属性,比如:图标、窗口栏、初始化的大小等等可以参考官方文档。

2.生成EXE可执行文件

将index.html和package.json这两个文件压缩到一个zip压缩包里,命名为app.zip

image-1665403575915

把app.zip这个文件的扩展名改为nw,变为 app.nw

将app.nw放置到nw.exe同一级目录,进入windows cmd后运行这个命令:

copy /b nw.exe+app.nw app.exe

然后会生成app.exe文件。

我们可以使用如下的几种方式安装到客户的电脑上:

  • 1.直接RAR打包,发给用户,这也就是个绿色版,无需安装。
  • 2.我们用软件工具 Enigma Virtual Box 封包,用这个工具可以把整个应用程序文件夹生成一个单独的app.exe, 用户直接双击就能运行,这个也是无需安装的。
  • 3.用软件工具innosetup,这个工具会生成一个安装版本。

3.修改icon

默认情况下创建出来的应用程序(exe)会和nw.exe的图标一样,可以通过resource hacker这个工具来修改nw.exe的图标成你所想要的。

打开resource hacker,找到对应的图片组资源(icon group),然后右击选择替换(replace)就可以了。

image-1665403646870

4.封包

在进行打包前,首先把我们在NWJS_SDK版本(是在NWJS_SDK版本下进行开发的)下的package.json、app.exe、app文件夹复制到NWJS_NORMAL版本中,并且删除NWJS_NORMAL版本中的nw.exe文件。

image-1665403667893

5. Enigma Virtual Box

官网上推荐用Enigma Virtual Box这个软件来将app.exe和依赖的dll打包成一个exe后发布

image-1665403697352

在选择待封包的主程(Enter Input File Name)输入app.exe的路径
在封包程序另存(Enter Output File Name)输入可执行程序的输出路径
拖入文件和文件夹,选择nwjs_normal的配置文件(除了app.exe的其它文件和文件夹)

image-1665403712509

点击封包后,封包结束后会得到app_boxed.exe。然后删除app_boxed.exe之外的所有文件和文件夹(如果在封装的时候没有拖入所有的文件,那么就不能删除那些未参与封包的文件),然后就可以得到最后的可执行文件app_boxed.exe

image-1665403726617

从截图可以看出,这个app_boxed.exe是免安装的,可以点击直接运行。这是Enigma Virtual Box封包的优点,无需安装直接运行,但缺点就是太大了,从截图可以看出app_boxed.exe达到了202MB。

6. Inno Setup

这是另一种打包方式,就是用Inno Setup来打包成安装程序,即将一开始的web应用源文件和node-webkit的nw.exe和一些以来dll直接压缩成一个安装文件,我们并不需要上述中间那先打包成app.exe的步骤。用户在使用你的exe后会出现setup wizard把程序安装到Program Files目录中,将nw.exe,dll,web应用释放出来,这个时候所生成的安装文件其实大小会小很多。

  • 下载安装运行后点击File->New即进入创建步骤

image-1665403876886

  • 填写应用发布的信息

image-1665403907830

  • 添加应用程序的打包文件

image-1665403924768

  • 执行后续操作,进行编译

image-1665404027189

  • 生成可执行EXE:

image-1665403825611

我们可以看出安装包的大小是54.3MB,Inno Setup的优点就是安装包小,但缺点就是需要进行安装。

原文链接:https://www.cnblogs.com/HDK2016/p/10877224.html

0

评论区