鸿蒙开发:应用内如何做更新

程序员一鸣
• 阅读 2

前言

本文基于Api13

应用更新是开发中一个比较常见的功能,便于我们把新的功能及时的推送出去,进而提醒用户有新的版本,便于用户及时的去体验下载,可以说,关系着我们APP功能的未来走向,是一个不能缺失而且非常重要的功能。

鸿蒙中的更新和Android有着非常大的区别,在Android中,apk可以自由下载安装,也就意味着,我们可以把apk托管到一个服务器中,在应用中就能让用户做到更新下载,而且非常的及时;然而鸿蒙中却做不到,鸿蒙中打出的包,由于纯净模式默认开启,只能上传到华为应用市场,在其他的渠道是无法进行更新下载的,目的也很明确,为了软件的安全,防止恶意软件入侵。

总结就是,在鸿蒙中更新应用,是无法做到直接下载更新的,而是必须到应用市场进行更新。

从另一个角度来看,对于开发者的我们确实简单了很多,不用在去考虑下载安装的逻辑,也不用考虑后台更新的逻辑,只需要调用系统给我们提供的更新方法就可以了。

更新呢,也有两种方式,一种是直接使用系统提供的更新样式,另一种就是自定义更新弹窗样式,无论哪种样式,最后都是需要跳转到应用市场。

调用系统更新样式

调用系统样式,非常的简单,无须我们再额外的处理弹窗样式,所有的功能从检查更新到弹窗,都有系统来提供,也就是通过updateManager里的两个方法,一个是checkAppUpdate检查更新,一个showUpdateDialog显示更新弹窗,源码如下:

/**
   * Check for Update.
   *
   * @param { common.UIAbilityContext } context - the context of an ability
   * @returns { Promise<CheckUpdateResult> } The promise of CheckUpdateResult returned by the function.
   * @throws { BusinessError } 401 - Parameter error.
   * @throws { BusinessError } 1009400001 - SA connect error
   * @throws { BusinessError } 1009400002 - Request to service error.
   * @throws { BusinessError } 1009400003 - Network error.
   * @throws { BusinessError } 1009400004 - The application is not in the foreground.
   * @throws { BusinessError } 1009400005 - Not agreeing to the privacy agreement.
   * @throws { BusinessError } 1009400006 - Time limited.
   * @throws { BusinessError } 1009400007 - Other error.
   * @syscap SystemCapability.AppGalleryService.Distribution.Update
   * @stagemodelonly
   * @since 5.0.0(12)
   */
  function checkAppUpdate(context: common.UIAbilityContext): Promise<CheckUpdateResult>;
  /**
   * Displaying the update dialog.
   *
   * @param { common.UIAbilityContext} context - the context of an ability
   * @returns { Promise<ShowUpdateResultCode> } The promise of ShowUpdateResultCode returned by the function.
   * @throws { BusinessError } 401 - Parameter error.
   * @throws { BusinessError } 1009400001 - SA connection error.
   * @throws { BusinessError } 1009400002 - Request to service error.
   * @throws { BusinessError } 1009400004 - The application is not in the foreground.
   * @throws { BusinessError } 1009400005 - Not agreeing to the privacy agreement.
   * @throws { BusinessError } 1009400007 - Other error.
   * @syscap SystemCapability.AppGalleryService.Distribution.Update
   * @stagemodelonly
   * @since 5.0.0(12)
   */
  function showUpdateDialog(context: common.UIAbilityContext): Promise<ShowUpdateResultCode>;

需要注意的是,两者必须结合使用,先去检查,再去显示更新弹窗,我们可以按照下面的代码逻辑去执行,在调用的时候,直接调用checkAppUpdate方法即可。

/**
   * 检查是否有更新,使用Promise方式异步返回结果
   */
  checkAppUpdate() {
    try {
      updateManager.checkAppUpdate(getContext() as common.UIAbilityContext)
        .then((checkResult: updateManager.CheckUpdateResult) => {
          //检查结果
          if (checkResult.updateAvailable == updateManager.UpdateAvailableCode.LATER_VERSION_EXIST) {
            //存在新的版本
            this.showUpdateDialog()
          }
        })
    } catch (error) {
    }
  }

  /**
   * 弹出更新弹窗
   */
  showUpdateDialog() {
    try {
      updateManager.showUpdateDialog(getContext() as common.UIAbilityContext)
    } catch (error) {
    }
  }

由于是返回的Promise,我们可以更加简单的使用await方法,代码更加的简单。

/**
  * 检查是否有更新,使用Promise方式异步返回结果
  */
 async checkAppUpdate() {
   let context = getContext() as common.UIAbilityContext
   let checkResult = await updateManager.checkAppUpdate(context)
   //检查结果
   if (checkResult.updateAvailable == updateManager.UpdateAvailableCode.LATER_VERSION_EXIST) {
     //存在新的版本
     updateManager.showUpdateDialog(context)
   }
 }

执行之后,就会显示如下的更新的弹窗,点击立即更新后,就会直接跳转到应用市场此应用的详情页面。

鸿蒙开发:应用内如何做更新

点击立即更新之后:

鸿蒙开发:应用内如何做更新

自定义弹窗样式

虽然说,鸿蒙不支持应用内更新下载,但是支持你自定义弹窗样式,只不过最后的更新,还是要去应用市场进行,实现步骤,第一步还是要调用系统的检查更新的方法,有更新时弹出自己的弹窗,然后实现跳转到应用市场详情页面。

检查更新

 /**
   * 检查是否有更新,使用Promise方式异步返回结果
   */
  async checkAppUpdate() {
    let context = getContext() as common.UIAbilityContext
    let checkResult = await updateManager.checkAppUpdate(context)
    //检查结果
    if (checkResult.updateAvailable == updateManager.UpdateAvailableCode.LATER_VERSION_EXIST) {
      //存在新的版本,弹出自己的视图,自己去定义

    }
  }

自定义弹窗这里就不写了,大家自行实现即可,当然,这里也推荐一下我的一个弹窗组件,有喜欢的朋友,可以进行体验,中心仓库地址是:

https://ohpm.openharmony.cn/#/cn/detail/@abner%2Fdialog

我这个弹窗,支持八大功能模块,几乎涵盖各个业务需求,【自定义形式】、【时间弹窗】、【城市选择】、【确认&信息】、【底部列表&网格】、【toast】、【popup形式】、【loading形式】,如果还不能满足,还支持便捷式自定义,可以说,让你的弹窗实现更加的便捷。

更新弹窗实现后,无非就是怎么跳转应用详情页面了,目前总结了三种方式,大家可以选择自己喜欢的方式。

跳转市场详情页面

方式一:loadProduct接口调用

主要是通过productViewManager中的loadProduct来拉起应用的详情页面,需要把bundleName替换为你自己的应用包名。

/**
   * productViewManager拉齐应用详情页
   */
  loadProduct() {
    const uiContext = getContext(this) as common.UIAbilityContext
    const wantParam: Want = {
      parameters: {
        // 必填,此处填入要加载的应用包名,例如: bundleName: 'com.huawei.hmsapp.books'
        bundleName: 'com.xx.xx',
      }
    }
    const callback: productViewManager.ProductViewCallback = {
      onError: (error: BusinessError) => {
        hilog.error(0, 'TAG', `loadService onError.code is ${error.code}, message is ${error.message}`)
      },
      onAppear: () => {
        hilog.info(0, 'TAG', `loadProduct onAppear.`);
      },
      onDisappear: () => {
        hilog.info(0, 'TAG', `loadProduct onDisappear.`);
      }
    }
    // 调用接口,拉起应用详情页
    productViewManager.loadProduct(uiContext, wantParam, callback);
  }

调用以上的方法后,就会跳转到应用的详情页面。

方式二:DeepLink方式

DeepLink方式是通过startAbility的方式进行跳转应用详情页面,也是需要应用的包名,其格式为:

store://appgallery.huawei.com/app/detail?id= + bundleName

实现跳转代码如下,定义外部的function函数。

// 拉起应用市场对应的应用详情页面
function startAppGalleryDetailAbility(context: common.UIAbilityContext, bundleName: string): void {
  let want: Want = {
    action: 'ohos.want.action.appdetail', //隐式指定action为ohos.want.action.appdetail
    uri: 'store://appgallery.huawei.com/app/detail?id=' + bundleName, //  bundleName为需要打开应用详情的应用包名
  };
  context.startAbility(want).then(() => {
    hilog.info(0x0001, 'TAG', "Succeeded in starting Ability successfully.")
  }).catch((error: BusinessError) => {
    hilog.error(0x0001, 'TAG', `Failed to startAbility.Code: ${error.code}, message is ${error.message}`);
  });
}

在需要跳转的时候,直接调佣,传入上下文和包名即可:

startAppGalleryDetailAbility(getContext() as common.UIAbilityContext,"com.xx.xx")

方式三:App Linking方式

App Linking的方式是通过openLink的方式跳转到应用市场详情页面,同样也是需要包名。其格式为:

https://appgallery.huawei.com/app/detail?id= + bundleName

跳转代码如下:

openLink(){
    let context: common.UIAbilityContext = getContext(this) as common.UIAbilityContext;
    // 需要拼接不同的应用包名,用以打开不同的应用详情页,例如:bundleName: 'com.huawei.hmsapp.books'
    let bundleName: string = 'com.xx.xx';
    let link: string = 'https://appgallery.huawei.com/app/detail?id=' + bundleName;
    // 以App Linking优先的方式在应用市场打开指定包名的应用详情页
    context.openLink(link, { appLinkingOnly: false })
      .then(() => {
        hilog.info(0x0001, 'TAG', 'openlink success.');
      })
      .catch((error: BusinessError) => {
        hilog.error(0x0001, 'TAG', `openlink failed. Code: ${error.code}, message is ${error.message}`);
      });
  }

相关总结

使用系统的,直接调用检查和显示更新弹窗即可,可以说就两个方法,我们就实现了应用更新的功能,可以说是非常的简单,如果系统的弹窗无法满足您的需求,您可以自定义弹窗,然后实现跳转应用详情页面即可。

本文标签:鸿蒙开发工具/应用更新

点赞
收藏
评论区
推荐文章
代码哈士奇 代码哈士奇
3年前
uniCloud+uni-admin+electron实现 electron应用更新
uniClouduniadminelectron实现electron应用更新搭建视频地址从https://gitee.com/dmhsq/reacttsviteelectron的仓库代码开始搭建两种更新方式1.资源替换(还可以更换成其它框架开发打包的asar资源)如下看效果2.安装包逻辑如下应用启动时调用检查更新方法检查更新方法查询
Stella981 Stella981
3年前
Android 经典笔记七 全局弹窗Dialog
目录介绍1.全局弹窗分析2.全局弹窗必要条件3.全局弹窗实现方式3.1.利用系统弹出dialog3.2.获取WindowManager,直接添加view3.3.在服务里,获取栈顶的Activity,弹窗4.Dialog实现全局Loading加载框4.1.自定义Loading类4.2.给自定义的
Stella981 Stella981
3年前
HarmonyOS应用开发项目实战
鸿蒙2.0已经发布了有段时间了,目前网上也有些小demo了,但是缺乏稍微大点的项目代码。我准备计划开发一个稍微正式点的项目,我写了个初略的项目需求清单,来体验鸿蒙应用开发。目前我已经着手实现了其中的一些重要功能,某些功能发现鸿蒙暂时不支持,但是还是先写上吧,后面慢慢摸索。我会陆续更新连载此贴,一步步从0基础讲解项目开发过程,然后巩固鸿蒙应用开发知识点。有错误
Stella981 Stella981
3年前
Location ios14最新版驱动使用教程,ios14 drivers下载安装
2020.09.16苹果发布了ios14正式版此次更新内容如下:1.来电弹窗功能以取代之前的来电提醒模式;2.桌面小部件功能;3.AppClip(小程序);4.允许第三方应用设成默认应用;5.画中画小窗,分屏;6.轻点背面实现截图等。
鸿蒙小林 鸿蒙小林
17小时前
《仿盒马》app开发技术分享-- 加入购物车&加购列表展示(12)
技术栈Appgalleryconnect开发准备上一节我们实现了商品详情页面的规格选择弹窗,这在任何购物类应用中都是最常用的功能之一。当然了,作为一个购物类的应用,我们仅仅展示是用处不大的,我们还需要有添加的动作。这一节我们就来实现添加到购车里并且在购物车
鸿蒙小林 鸿蒙小林
17小时前
《仿盒马》app开发技术分享-- 分类模块顶部导航列表弹窗(16)
技术栈Appgalleryconnect开发准备上一节我们实现了分类页面的顶部导航栏列表,并且实现了首页金刚区跟首页导航栏的联动,这一节我们实现导航栏列表的弹窗功能,需要学习的知识点有自定义弹窗,同时我们的数据源需要跟分类页保持一一致。功能分析1.弹窗自定
鸿蒙小林 鸿蒙小林
10小时前
《仿盒马》app开发技术分享-- 个人信息页(23)
技术栈Appgalleryconnect开发准备上一节我们实现了个人中心的业务逻辑,实现了个人信息修改后的动态更换,而且实现了一个静态的头像选择弹窗,但是这个弹窗我们并没有使用。这一节我们在个人信息页面就会使用到这个弹窗并且还涉及其他的弹窗。以及信息的同步
程序员一鸣 程序员一鸣
2天前
鸿蒙开发:实现popup弹窗
目前提供了两种方式实现popup弹窗,主推系统实现的方式,几乎能满足我们常见的所有场景,当然了,文章毕竟有限,尽量还是以官网为主。
布局王 布局王
16小时前
详解HarmonyOS NEXT仓颉开发语言中的全局弹窗
之前分享过仓颉开发语言中的自定义弹窗,那一次的自定义弹窗需要在对应页面先初始化再进行弹出,不是很方便。今天分享一下不依赖页面的全局弹窗。仓颉提供了全局弹窗模块promptaction,使用之前先将它导入:importohos.promptaction.该模
鸿蒙小林 鸿蒙小林
17小时前
《仿盒马》app开发技术分享-- 商品规格弹窗(11)
技术栈Appgalleryconnect开发准备上一节我们实现了商品详情页面,并且成功在页面上展示了商品的图片、商品规格、活动详情等信息,要知道同一种商品大多数都是有多种型号跟规格的,所以这一节我们来实现商品的规格弹窗。这节的要点是自定义弹窗的运用。功能分