配置热更新
热更新的原理:
这一步我就不上图了,服务器上的chcp.manifest文件对比本地生成的chcp.manifest中的hash值,如果hash值对应的文件发生更改,通过chcp.json中设置的文件存放地址,进行文件流的下载更新。
安装热更新cli
- npm install -g cordova-hot-code-push-cli
安装热更新插件
ionic cordova plugin add cordova-hot-code-push-plugin
开发使用可以安装配套插件
cordova plugin add cordova-hot-code-push-local-dev-addon
使用热更新
*插件安装完毕,在www目录下面,会生成两个文件,chcp.json文件,跟chcp.manifest文件。当你运行corodva-hcp server的时候,你每更改一个文件,chcp.manifest跟chcp.json就会发生相应的更改。
*但是生成的地址会变成一个临时的镜像地址,所以需要添加一个cordova-hcp.json 文件模板。这时候不需要启动cordova-hcp server,直接启动cordova-hcp build
cordova-hcp.json文件内容大致如下
"content_url": "http://yourserverAddress/www", //远程地址www后面不要加上/
"update": "now"//分三种情况
// start - app启动时安装更新. 默认值.
// resume - app从后台切换过来的时候安装更新.
// now - web内容下载完毕即安装更新.
"release": "2017.07.01-15.52.14", //版本号
"min_native_interface": 1 //min_native_interface:版本设置。
在config.xml我们设置的native-interface version=5 那么我们生成的就会是
"min_native_interface":5
- 插件安装完毕,需要在config.xml文件里面添加
<chcp>
<native-interface version="1" />
<config-file url=".../chcp.json" />
<chcp/>
...为你的服务器地址。
定义当前版本:
<chcp>
<native-interface version="5" />
</chcp>
如果你应用程序的版本比服务器的版本还高,那么插件将不会从服务器加载新的更新,默认设置为1。
自动下载:
<chcp>
<auto-download enabled="false" />
</chcp>
定义插件是否允许下载更新。最初更新提取是自动执行的,可以禁用它,并通过JavaScript模块手动执行。默认情况下,首选项设置为true。
自动安装:
<chcp>
<auto-install enabled="false" />
</chcp>
定义插件是否允许安装更新。最初更新安装是自动执行的,可以禁用它,并通过JavaScript模块手动执行。默认情况下,首选项设置为true。
- 如果你的服务器,无法接受跨域访问的话,热更新插件很可能会不成功,所以可以更改服务器的配置,使其接受跨域下的访问,插件才能从服务器上把文件给下载下来。
简单的说明
可用事件
chcp_updateIsReadyToInstall - web内容已经下载并可以安装时触发.
chcp_updateLoadFailed - 插件无法下载web更新时触发. 详细错误信息在事件参数里.
chcp_nothingToUpdate - 无可用更新下载时触发.
chcp_updateInstalled - web内容安装成功时触发.
chcp_updateInstallFailed - web内容安装失败时触发. 详细错误信息在事件参数里.
chcp_nothingToInstall -无可用更新安装时触发.
chcp_assetsInstalledOnExternalStorage - 插件成功把app内置的web内容拷贝到外置存储中时触发. 你可能需要开发调试时用到这个事件,也许不会.
chcp_assetsInstallationError -插件无法拷贝app内置的web内容到外置存储中时触发. 如果此事件发生了 - 插件不再工作. 也许是设备没有足够的存储空间导致. 详细错误信息在事件参数里.
在需要使用热更新的文件中声明
declear var chcp:any //防止程序提示找不到chcp
更加详细的说明跟使用可以参考
http://blog.csdn.net/lovelyelfpop/article/details/50848524
或者
http://www.jianshu.com/p/9e3cd54f5f97