探索cordova項目前段時間增長了熱更新功能,本身第一次作的時候在網上查找了不少資料,有的資料寫的並不全面遇到了不少坑。所以總結一些在開發過程當中遇到了問題和解決辦法。html
這裏不涉及app版本更新,只是熱更新。android
此更新方式,只須要更新web前段代碼,不須要更新android的原生代碼。只是對js、html等的更新。ios
cordova plugin add cordova-hot-code-push-plugin
npm install -g cordova-hot-code-push-cli
此文件是用於方便生成www文件下chcp.json文件的內容。git
執行命令(必須在項目根目錄執行更新工具的命令)github
cordova-hcp init 生成熱更新相關配置文件
生成的默認應用程序配置文件(cordova-hcp.json)在項目根文件夾中。web
cordova-hcp.json文件內容:npm
{
"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 這個值執行命令後是沒有的須要本身手動添加,若是不添加網頁內容更新將會無效。json
執行命令服務器
cordova-hcp build
執行此命令會在chcp.json文件中增長"release":"當前時間"
字段。(默認使用時間戳,格式爲:yyyy.MM.dd-HH.mm.ss),插件將版本號進行字符串相等比較來判斷是否存在新版本。app
"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>
運行cordova build android生成具備熱更行功能的安卓app安裝包。
這一步我是直接將項目更改後的的www文件夾放到服務器上,在cordova項目根目錄運行 cordova-hcp build, 而後重啓app,就可實現App的web內容代碼的熱更新了。須要注意的是www文件在服務地地址必定要與"content_url":"http://************/cordova/www"
和config.xml中<config-file url="https://************/cordova/www/chcp.json" />
填寫的地址一致。