Electron应用打包
概要
为舒缓Windows
下路径名过长的问题,也略对require
加速以及简单隐匿你的源代码,你可以通过极小的源代码改动将你的应用打包成 asar
。
生成 asar 包
asar
是一种将多个文件合并成一个文件的类 tar 风格的归档格式。Electron
可以无需解压,即从其中读取任意文件内容。
参照如下步骤将你的应用打包成 asar
:
asar
1. 安装 $ npm install -g asar
asar pack
打包
2. 用 $ asar pack your-app app.asar
3. 使用 asar 包
在 Electron
中有两类 APIs:Node.js 提供的 Node API
和 Chromium
提供的 Web API
。这两种 API
都支持从 asar
包中读取文件。
Node API
由于 Electron
中打了特别补丁, Node API
中如 fs.readFile
或者 require
之类的方法可以将 asar
视之为虚拟文件夹,读取 asar
里面的文件就和从真实的文件系统中读取一样。
例如,假设我们在 /path/to
文件夹下有个 example.asar
包:
$ asar list /path/to/example.asar
/app.js
/file.txt
/dir/module.js
/static/index.html
/static/main.css
/static/jquery.min.js
从 asar
包读取一个文件:
const fs = require('fs');
fs.readFileSync('/path/to/example.asar/file.txt');
列出 asar
包中根目录下的所有文件:
const fs = require('fs');
fs.readdirSync('/path/to/example.asar');
使用 asar
包中的一个模块:
require('/path/to/example.asar/dir/module.js');
你也可以使用 BrowserWindow
来显示一个 asar
包里的 web
页面:
const BrowserWindow = require('electron').BrowserWindow;
var win = new BrowserWindow({width: 800, height: 600});
win.loadURL('file:///path/to/example.asar/static/index.html');
Web API
在 Web
页面里,用 file:
协议可以获取 asar
包中文件。和 Node API
一样,视 asar
包如虚拟文件夹。
例如,用 $.get
获取文件:
<script>
var $ = require('./jquery.min.js');
$.get('file:///path/to/example.asar/file.txt', function(data) {
console.log(data);
});
</script>
Node API 缺陷
尽管我们已经尽了最大努力使得 asar
包在 Node API
下的应用尽可能的趋向于真实的目录结构,但仍有一些底层 Node API
我们无法保证其正常工作。
asar
包是只读的asar
包中的内容不可更改,所以 Node APIs 里那些可以用来修改文件的方法在对asar
包时都无法正常工作。