探索cordova项目前段时间增加了热更新功能,自己第一次做的时候在网上查找了很多资料,有的资料写的并不全面遇到了很多坑。因此总结一些在开发过程中遇到了问题和解决办法。
这里不涉及app版本更新,只是热更新。
此更新方式,只需要更新web前段代码,不需要更新android的原生代码。只是对js、html等的更新。
cordova plugin add cordova-hot-code-push-plugin
npm install -g cordova-hot-code-push-cli
此文件是用于方便生成www文件下chcp.json文件的内容。
执行命令(必须在项目根目录执行更新工具的命令)
cordova-hcp init
生成的默认应用程序配置文件(cordova-hcp.json)在项目根文件夹中。
cordova-hcp.json文件内容:
{
"name": "",//可为空
"autogenerated": true,//如果不添加,热更新会不能使用
"ios_identifier": "id123456789",//应用在App store id(可为空)
"android_identifier": "",//应用在应用商城上的地址或者App的下载地址(可为空)
"update": "start",//在应用启动时安装
"min_native_interface": 1,//可用以做App升级(可以不填)
"content_url":
"http://************/cordova/www"//www文件在服务器上的地址
}
"autogenerated": true 这个值执行命令后是没有的需要自己手动添加,如果不添加网页内容更新将会无效。
执行命令
cordova-hcp build
执行此命令会在chcp.json文件中增加"release":"当前时间"
字段。(默认使用时间戳,格式为:yyyy.MM.dd-HH.mm.ss),插件将版本号进行字符串相等比较来判断是否存在新版本。
"release": "2017.06.07-16.30.20",//唯一web项目版本号,用与热更新web内容的更新。(必需)
最好写在底部方便以后配置修改
<chcp>
<auto-download enabled="true" />
<auto-install enabled="true" />
<native-interface version="1" />
<config-file url="https://************/cordova/www/chcp.json" />
</chcp>
这一步我是直接将项目的www文件夹放到服务器上,在cordova项目根目录运行 cordova-hcp build, 然后重启app,就可实现App的web内容代码的热更新了。需要注意的是www文件在服务地地址一定要与"content_url":"http://************/cordova/www"
和config.xml中<config-file url="https://************/cordova/www/chcp.json" />
填写的地址一致。
原文:https://www.cnblogs.com/changzz/p/10763986.html