因为项目需要,使用cordova的热更新插件,本地调试很简单,看连接https://github.com/nordnet/cordova-hot-code-push,就几步,这里不说了。

下面两个要装下

  npm install -g cordova-hot-code-push-cli(用来动态生成chcp.json和chcp.manifest两个文件)

cordova plugin add cordova-hot-code-push-plugin (插件)

真正放到服务器老是不管用,查看源码:

  

  

 // check if new version is available
if ([newAppConfig.contentConfig.releaseVersion isEqualToString:_oldAppConfig.contentConfig.releaseVersion]) {
[self notifyNothingToUpdate:newAppConfig];
return;
}

  逻辑其实特别简单,对比当前应用内和你服务器上的releaseversion,如果不一样,就去加载服务器的www文件,然后对比chcp.manifest下的hash值,更新文件,下次再打开应用时,就使用新的文件。记住是下次打开应用,才使用新的文件。

    

    放服务器上,注意几点:

  1.config.xml添加节点如下:

  <chcp>
    <config-file url="http:/yourserver/www/chcp.json" />
  </chcp>

  2.生成平台代码,把平台代码下www文件夹下的chcp.json的content_url改成:

    http:/yourserver/www,确认对应的config.xml下chcp节点是对的。

    运行对应平台代码。

  3.命令进入自己项目根目录,运行cordova-hcp build,这个运行后,它会自动去改chcp.json下的release值, 

   和chcp.manifest下的改过的文件的hash值

  4.把你改过的文件,chcp.json,chcp.manifest这些本地的放到服务器上。覆盖对应的文件(当然都在www文件夹下,可以直接上传www)。

  git官网上讲的是本地服务器测试,没什么问题,放到自己服务器,还是要注意下。当然不理解很容易急,最好就是自己在oc里打断点,看到releaseversion是不是一样,然后下载后的文件是不是一样,就知道你哪里改的不对了。

  另外,其他一些问题:

  如果你跑cordova-hcp build,它会去生成chcp.json,那里面的值就改了,可以在项目根目录建一个cordova-hcp.json,写一些default配置

  cordova-hcp.json 可以长这样
  

{
"content_url": "http://yourserverAddress/www",
"autogenerated": true,
"update": "now"
}

  

  IOS

  ios里报_-swift.h找不到,把这个改成  项目名-swift.h,

cordova.js一定要引用,下面的代码最终走到上面真正的去下载的地方,首先是js的

1.

// Called when Cordova is ready for work.
// Here we will send default callback to the native side through which it will send to us different events.
channel.onCordovaReady.subscribe(function() {
ensureCustomEventExists();
exec(nativeCallback, null, PLUGIN_NAME, pluginNativeMethod.INITIALIZE, []);
});

// Plugin methods on the native side that can be called from JavaScript

pluginNativeMethod = {

INITIALIZE: 'jsInitPlugin',

FETCH_UPDATE: 'jsFetchUpdate',

INSTALL_UPDATE: 'jsInstallUpdate',

CONFIGURE: 'jsConfigure',

REQUEST_APP_UPDATE: 'jsRequestAppUpdate',

IS_UPDATE_AVAILABLE_FOR_INSTALLATION: 'jsIsUpdateAvailableForInstallation',

GET_INFO: 'jsGetVersionInfo'

};

上面的jsInitPlugin,就在oc里,就是每次你启动app,初始化插件时,走这个jsInitPlugin,方法执行循序:

jsInitPlugin-->

[self _fetchUpdate:nil withOptions:nil]-->

[self _fetchUpdate:command.callbackId withOptions:fetchOptions]-->

[[HCPUpdateLoader sharedInstance] executeDownloadRequest:request error:&error] -->

[self executeTask:task]-->

[task runWithComplitionBlock:^{ _isExecuting = NO;}]-->

- (void)runWithComplitionBlock:(void (^)(void))updateLoaderComplitionBlock{

这里就是上面的更新代码

}

https://github.com/nordnet/cordova-hot-code-push/issues/223

  

ionic cordova 热更新的更多相关文章

  1. ionic cordova 热更新(引用自www.zyyapp.com/post/116.html)

    上篇文章cordova 把html打包成安卓应用 http://www.zyyapp.com/post/115.html cordova 热更新是一个大坑,我看了一天一夜才明白.网上的教程都没说到重点 ...

  2. ionic cordova 热更新的一些问题

    因为项目需要用到更新这一块的东西,所以就查了下cordova 的热更新,然后遇到了 一些问题,记录下来备忘. 项目用的是ionic 下载cordova的内容就直接跳过了. 首先是下载cordova的插 ...

  3. Ionic APP 热更新 之 产品发布状态下的热更新搭建,去local-dev-addon插件

    上一篇,我们介绍了在本地开发环境下的ionic项目热更新测试, 本文,我们将详细说明如何在去掉cordova-hot-code-push-local-dev-addon插件的情况下,实现热更新. 使用 ...

  4. Ionic APP 热更新

    开门见山,本文主题:cordova-hot-code-push 作用:cordova热更新插件,提供了在应用程序中对基于Web的内容进行自动更新的功能. GitHub地址:https://github ...

  5. cordova热更新

    cordova 热更新: 一.添加插件 1.新建Cordova项目 cordova create CordovaHotCode com.ezample.hotcode 2.添加Android平台 在新 ...

  6. Cordova热更新和App升级 - 简书

    原文:Cordova热更新和App升级 - 简书 公司的cordova项目前段时间增加了热更新功能,自己第一次做的时候在网上查找了很多资料,有的资料写的并不全面遇到了很多坑.因此总结一些在开发过程中遇 ...

  7. ionic 3 热更新 Hot Code Push

    最近用ionic 3 做的app业务做的差不多了,突然想到以后app如果有更新该怎么搞?想到我们的app后期更新应该不大,,最多就是改改bug和增加下用户体验,如果只有一些小的更新,然后提交各个应用商 ...

  8. Cordova热更新cordova-hot-code-push

    原文转载自:https://www.cnblogs.com/huangenai/p/7137475.html cordova-hot-code-push ,Cordova热代码推送插件提供了在应用程序 ...

  9. cordova热更新插件的使用:cordova-hot-code-push-plugin

    1. 添加插件:cordova plugin add cordova-hot-code-push-plugin 2. 先打开cli,执行命令 npm install -g cordova-hot-co ...

随机推荐

  1. BZOJ1841 : 蚂蚁搬家

    树分治,对于每个分治结构,维护两棵线段树. 第一棵按dfs序维护所有点到重心的距离,第二棵维护每个分支的最长链. 那么当前结构对答案的贡献就是第二棵线段树的最大值$+$次大值. 对于操作$0$,如果是 ...

  2. 【转】SpringTest框架JUnit单元测试用例获取ApplicationContext实例的方法

    转自:http://www.coderli.com/junit-spring-test-applicationcontext JUnit单元测试用例中使用Spring框架,直接方式如下. @RunWi ...

  3. 【转】敏捷开发 Scrum 总结

    转:http://www.open-open.com/lib/view/open1330413325514.html 最近把之前学习 Scrum 的资料整理为一篇文档,在接下来的团队和项目开发中,根据 ...

  4. Codeforces Round #353 (Div. 2)Restoring Painting

    Vasya works as a watchman in the gallery. Unfortunately, one of the most expensive paintings was sto ...

  5. [深入浅出Windows 10]布局原理

    5.2 布局原理 很多时候在编写程序界面的时候都会忽略了应用布局的重要性,仅仅只是把布局看作是对UI元素的排列,只要能实现布局的效果就可以了,但是在实际的产品开发中这是远远不够的,你可能面临要实现的布 ...

  6. 数组的Clone方法

    public void Test() { ,,}; var arr2 = arr1; var arr3 = (int[])arr1.Clone(); //浅拷贝 arr1[] = ; //arr2[0 ...

  7. Java生成动态GIF图片

    写selenium自动化时,为了查看运行效果,后给浏览器截图,想到可以生成gif图片来快速预览.看到已经有人实现了,直接拿过来. 共涉及到三个java文件,分别是NeuQuant.java,LZWEn ...

  8. marquee滚动语法

    <html> <head> <meta http-equiv="Content-Type" content="text/html; char ...

  9. 最长递增子序列 O(NlogN)算法

    转自:点击打开链接 最长递增子序列,Longest Increasing Subsequence 下面我们简记为 LIS. 排序+LCS算法 以及 DP算法就忽略了,这两个太容易理解了. 假设存在一个 ...

  10. Js特效--模仿滚动条(兼容IE8+,FF,Google)

    <html> <head> <style> *{margin:0px;padding:0px;} #box{width:200px;height:500px;pos ...