DCloud_UNI_CHB
DCloud_UNI_CHB
  • 发布:2018-08-30 18:40
  • 更新:5 天前
  • 阅读:94478

uni-app 整包升级/更新方案

分类:uni-app

使用 uni-app 开发,可将代码编译到iOS、Android、微信小程序等多个平台,升级时也需考虑多平台同步升级。

uni-app发布为小程序的升级模式较简单,只需将开发完的代码提交小程序后台,待审核通过后用户将自动升级。

App端的升级,又分为整包更新和资源热更新两种。

  • 整包更新,即常规的整个App安装包重新下载安装。
  • 资源热更新,即App并重新安装,里面的js等前端代码进行更新。

资源热更新另见文档:http://ask.dcloud.net.cn/article/35667

官方已发布APP升级中心,支持原生APP整包升级和wgt资源包升级。详见

本文重点讲解整包更新。

一般iOS Appstore的安装包,无法直接更新。App启动后检查有新版本,只能调整到Appstore,然后用户在Appstore的详情页点击更新按钮。

而Android App,可以直接下载新的apk,只要包名和证书不变,就可以覆盖安装。

App升级,强烈推荐使用uniCloud。

  1. 把apk存放到uniCloud的cdn上,可以免费使用
  2. 有现成的插件,不用写升级逻辑,打好安装包,发布管理,检查升级都可以直接用,详见:https://ext.dcloud.net.cn/plugin?id=4470

如果不使用uniCloud,自己也可以写升级逻辑,下文讲解了常见的逻辑,但下文不是DCloud约定的强制逻辑,只是一般性常见做法的介绍。

接口约定

如下数据接口约定仅为示例,开发者可以自定义接口参数。

请求地址:https://www.example.com/update

请求方法:GET

请求数据:

{  
    "appid": plus.runtime.appid,  
    "version": plus.runtime.version  
}

响应数据:

{  
    "status":1,//升级标志,1:需要升级;0:无需升级  
    "note": "修复bug1;\n修复bug2;",//release notes  
    "url": "http://www.example.com/uniapp.apk" //更新包下载地址  
}

客户端实现

App启动时,向服务端上报当前版本号,服务端判断是否提示升级。

在App.vue的onLaunch中,发起升级检测请求,如下:

onLaunch: function () {  
    //#ifdef APP-PLUS  
    var server = "https://www.example.com/update"; //检查更新地址  
    var req = { //升级检测数据  
        "appid": plus.runtime.appid,  
        "version": plus.runtime.version  
    };  
    uni.request({  
        url: server,  
        data: req,  
        success: (res) => {  
            if (res.statusCode == 200 && res.data.status === 1) {  
                uni.showModal({ //提醒用户更新  
                    title: "更新提示",  
                    content: res.data.note,  
                    success: (res) => {  
                        if (res.confirm) {  
                            plus.runtime.openURL(res.data.url);  
                        }  
                    }  
                })  
            }  
        }  
    })  
    //#endif  
}

注意:App的升级检测代码必须使用条件编译,否则在非App环境由于不存在plus相关API,将会报错。

升级地址URL,如果是自行托管的App,就提供自己的包地址。如果是打开应用市场,那URL如下:

if (plus.os.name=="Android") {  
    appurl = "market://details?id=io.dcloud.hellouniapp"; //这个是通用应用市场,如果想指定某个应用商店,需要单独查这个应用商店的包名或scheme及参数  
}  
else{  
    appurl = "itms-apps://itunes.apple.com/cn/app/hello-uni-app/id1417078253";  
}

服务端实现

根据客户端上报的版本号,比对服务端最新版本号,决定是否需要升级,若需升级则返回升级信息(rease notes、更新包地址等)

实现示例:

  1. 【推荐】通过uniCloud的云函数模板,快速实现升级检查逻辑,详情参考:https://ext.dcloud.net.cn/plugin?id=4470
  2. php示例代码:
header("Content-type:text/json");  
$appid = $_GET["appid"];  
$version = $_GET["version"]; //客户端版本号  
$rsp = array("status" => 0); //默认返回值,不需要升级  
if (isset($appid) && isset($version)) {  
    if ($appid === "__UNI__123456") { //校验appid  
        if ($version !== "1.0.1") { //这里是示例代码,真实业务上,最新版本号及relase notes可以存储在数据库或文件中  
            $rsp["status"] = 1;  
            $rsp["note"] = "修复bug1;\n修复bug2;"; //release notes  
            $rsp["url"] = "http://www.example.com/uniapp.apk"; //应用升级包下载地址  
        }  
    }  
}   
echo json_encode($rsp);  
exit;

常见问题

  1. 版本检测需要打包app,真机运行基座无法测试。因为真机运行的plus.runtime.version是固定值。
37 关注 分享
Trust 270635897@qq.com caiqihuang@126.com dev7 水灵退散 wzl16 DCloud_UNI_CHB 没得好名字 qq820805144 12003@qq.com 沧桑 1172106013@qq.com sonicsunsky@qq.com wuguangyong CodeIsLaw 草灯 1157817265@qq.com 642307404@qq.com 306816224@qq.com Iain shanjixiaboss@163.com 江西来客 392660515@qq.com 知行合一 324166166@qq.com ai666 weliff@163.com ximida@163.com 786395613 rysnone 113476114@qq.com 奶凶的喵咪 dyjx2004 546506705@qq.com 小胖子783 1061096367@qq.com 517800851@qq.com

要回复文章请先登录注册

373654981@qq.com

373654981@qq.com

plus.downloader.createDownload在自定义基座怎么下载失败?: at android.support.v4.content.FileProvider.parsePathStrategy(FileProvider.java:605)
2021-04-08 16:55:16.870 23270-23795/com.gsc.test W/System.err: at android.support.v4.content.FileProvider.getPathStrategy(FileProvider.java:579)
2021-04-08 16:55:16.870 23270-23795/com.gsc.test W/System.err: at android.support.v4.content.FileProvider.getUriForFile(FileProvider.java:417)
2021-04-08 16:55:16.870 23270-23795/com.gsc.test W/System.err: at io.dcloud.common.util.LoadAppUtils.getDataAndTypeIntent(Unknown Source:650)
2021-04-08 16:55:16.870 23270-23795/com.gsc.test W/System.err: at io.dcloud.common.adapter.util.PlatformUtil.openFileBySystem(Unknown Source:196)
2021-04-08 16:55:16.870 23270-23795/com.gsc.test W/System.err: at io.dcloud.common.a.a.a(Unknown Source:1232)
2021-04-08 16:55:16.870 23270-23795/com.gsc.test W/System.err: at io.dcloud.common.a.a.processEvent(Unknown Source:402)
2021-04-08 16:55:16.870 23270-23795/com.gsc.test W/System.err: at io.dcloud.common.core.b.dispatchEvent(Unknown Source:638)
2021-04-08 16:55:16.870 23270-23795/com.gsc.test W/System.err: at io.dcloud.feature.b.processEvent(Unknown Source:104)
2021-04-08 16:55:16.870 23270-23795/com.gsc.test W/System.err: at io.dcloud.feature.pdr.RuntimeFeatureImpl$1.run(Unknown Source:232)
2021-04-08 16:55:16.870 23270-23795/com.gsc.test E/appmgr: installWebApp /storage/emulated/0/Android/data/com.gsc.test/downloads/app(14).apk is Illegal path
5 天前
whysohandsome@qq.com

whysohandsome@qq.com

回复 719728036@qq.com :
同疑惑
2021-03-16 21:27
xiaojun617

xiaojun617

plus.runtime.openURL(res.data.url); 下载.apk文件完成,安装时提示“无法打开文件”,应该是系统权限问题
Android10,小米MIUI12,所以这种方式用不了,有没有其他简易方法下载安装apk?
2021-01-19 10:17
hws007

hws007

回复 chualosue :
对,要先下载,才能安装,要本地这文件
2020-12-17 02:01
DCloud_iOS_XHY

DCloud_iOS_XHY

回复 overbalance40@gmail.com :
releaseAppResourceToRunPathWithAppid 必须运行成功才行,1.检查wgt是否真正下载成功;2.检查传入的本地wgt路径是否正确,注意路径不是URL不需要file://协议头,直接传本地路径即可
2020-12-14 12:08
overbalance40@gmail.com

overbalance40@gmail.com

有哪位大神知道这个问题的:iOS这边更新小程序(小程序资源部署在后台,检测到有新版本,ios这边就去下载),下载成功之后[DCUniMPSDKEngine releaseAppResourceToRunPathWithAppid:appId resourceFilePath:filePath];添加进去,但是这个方法返回nil,下载是完成了的。运行提示就是uni小程序(__UNI__5DExxxx)不存在。但是杀死app再重启,就能正常运行了。。。。求大神指导
2020-12-12 11:24
398927951@qq.com

398927951@qq.com

回复 gangyukj@163.com :
同发现这个问题,更新后Android会出现页面错位,然后重启app也可以得到解决
2020-12-10 09:06
1483880803@qq.com

1483880803@qq.com

回复 137608529@qq.com :
用这种方法从后台下载apk包速度很慢是怎么回事
2020-11-30 11:02
小白UNI

小白UNI

回复 493885262@qq.com :
问题解决了没
2020-11-19 17:49
小白UNI

小白UNI

回复 gangyukj@163.com :
问题解决了没
2020-11-19 17:49