uni-app资源包、增量(热更新)升级

生成 App 资源升级包

修改版本号
更新 manifest.json 中的版本号。
例:若原先版本为 1.0.0,那么新版本应该是 1.0.1 或 1.1.0

发行

在 HBuilderX 中生成升级包(wgt)。
菜单->发行->原生App-制作移动App资源升级包

存放资源

将 xxxx.wgt 文件存放在服务器的 static 目录下,即
https://www.xxx.com/static/wgt/xxxx.wgt

检测是否存在新版本

//获取App版本号
getAppVersion() {
    let that = this;
    plus.runtime.getProperty(plus.runtime.appid, (wgtinfo) => {
        that.appVersion = wgtinfo.version;
        that.checkUpdate()
    });
},
//检查更新
checkUpdate: function() {
    let that = this;            
        getAppUpdate({
        platform: that.getPlatform() == 'android' ? 2 : 1,
            appVersion: that.appVersion
    }).then(function(res) {
       if (!res) return;
       if (res.data) {
        if (res.data.versionChanged == 'true') {
            that.checkInfo.wgtUrl = res.data.wgtUrl;
            that.checkInfo.content = res.data.content;
            that.checkInfo.foces = res.data.foces;//是否需要强制更新
            that.$refs.popupUpgrade.open();
        } 
       } else {
        plus.nativeUI.toast("获取数据失败")
      }
    }).catch(function(error) {
        plus.nativeUI.toast("请检查网络连接")
    });
},

提示更新资源信息

image.png
this.$refs.popupUpgrade.open();

下载资源包

image.png
downWgt(path) {
  let that = this;
  // 在线升级app/热更新
  const downloadTask = uni.downloadFile({ //下载文件
    url: path,
    success: (downloadResult) => {
    if (downloadResult.statusCode === 200) {
      // 更新升级
          plus.runtime.install(downloadResult.tempFilePath,       {
        force: false
    }, function() {
      // console.log('install success...');
       plus.nativeUI.alert("应用资源更新完成!", function() {
          plus.runtime.restart();
       });
    }, function(e) {
        plus.nativeUI.toast("更新失败,请稍后再试");
    });
    }
  }
});
                
  downloadTask.onProgressUpdate((res) => { //下载文件的进度
    // console.log('downloatTask',res);
    that.downloadSize = res.totalBytesWritten; //当前下载大小
    that.prg = res.progress; //当前下载比例
    that.totalSize = res.totalBytesExpectedToWrite; //
  });
},

重启App

 plus.runtime.restart();

注意事项

应用市场为了防止开发者不经市场审核许可,给用户提供违法内容,对热更新大多持排斥态度。

但实际上热更新使用非常普遍,不管是原生开发中还是跨平台开发。

Apple曾经禁止过jspatch,但没有打击其他的热更新方案,包括cordovar、react native、DCloud。封杀jspatch其实是因为jspatch有严重安全漏洞,可以被黑客利用,造成三方黑客可篡改其他App的数据。

使用热更新需要注意:

上架审核期间不要弹出热更新提示
热更新内容使用https下载,避免被三方网络劫持
不要更新违法内容、不要通过热更新破坏应用市场的利益,比如iOS的虚拟支付要老老实实给Apple分钱
如果你的应用没有犯这些错误,应用市场是不会管的。

参考资料

https://ask.dcloud.net.cn/article/35667

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容