HarmonyOS 鸿蒙Next中应用检查新版本的功能如何开发

HarmonyOS 鸿蒙Next中应用检查新版本的功能如何开发 大家好,想问一下那种在自己的应用内主动检查是否有新版本的功能是怎么加的啊?谢谢了。

8 回复

开发者你好,可以使用应用市场服务的检查应用新版本功能,调用checkAppUpdate方法检查应用版本是否有更新。

try {
  updateManager.checkAppUpdate(context)
    .then((checkResult: updateManager.CheckUpdateResult) => {
      hilog.info(0, 'TAG', "Succeeded in checking Result updateAvailable:" + checkResult.updateAvailable);
    }).catch((error: BusinessError) => {
    hilog.error(0, 'TAG', `checkAppUpdate onError.code is ${error.code}, message is ${error.message}`);
  });
} catch (error) {
  hilog.error(0, 'TAG', `checkAppUpdate onError.code is ${error.code}, message is ${error.message}`);
}

说明

  • 本地安装版本须低于应用市场在架版本才能检查到更新。
  • 本地安装版本须和应用市场在架版本签名信息保持一致。
  • 暂不支持邀请测试和公开测试。

更多关于HarmonyOS 鸿蒙Next中应用检查新版本的功能如何开发的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html


学习了,

学习了。

华为官方提供的 updateManager API

可以使用应用市场检测更新:

https://developer.huawei.com/consumer/cn/doc/harmonyos-guides/store-update#检测应用新版本

在HarmonyOS NEXT中,使用@ohos.bundle.bundleManagergetBundleInfoForSelfSync()获取当前版本号,再通过@ohos.net.http发起网络请求获取服务器JSON中的最新版本号,比较后决定是否弹出更新提示。若需跳转应用市场,可调用@ohos.appMarketopenAppStore()

在 HarmonyOS Next 中实现“应用内检查新版本”,通常指自建版本检测逻辑,而非依赖系统 OTA。步骤如下:

  1. 获取当前应用版本
    使用 bundleManager 查询包信息:

    import bundleManager from '[@ohos](/user/ohos).bundle.bundleManager';
    const bundleInfo = await bundleManager.getBundleInfoForSelf(bundleManager.BundleFlag.GET_BUNDLE_INFO_WITH_APPLICATION_INFO);
    const currentVersion = bundleInfo.versionName; // 如 "1.0.0"
    
  2. 请求服务端最新版本
    通过 HTTP 请求自己的后端接口,获取最新版本号和下载地址:

    import http from '[@ohos](/user/ohos).net.http';
    const response = await http.createHttp().request('https://your-api/latest-version');
    const { version: latestVersion, downloadUrl } = JSON.parse(response.result as string);
    
  3. 比较版本号
    使用简单的字符串比较或语义版本对比,例如 currentVersion !== latestVersion 时视为有更新。

  4. 提示用户并引导更新
    弹窗确认后,使用 Want 跳转浏览器或应用商店详情页下载新包:

    import { common, Want } from '[@kit](/user/kit).AbilityKit';
    const context = getContext(this) as common.UIAbilityContext;
    const want: Want = {
      uri: downloadUrl, // 或应用商店的 scheme
      action: 'ohos.want.action.viewData'
    };
    context.startAbility(want);
    

    如希望直接拉起华为应用市场,可将 uri 改为应用的市场详情链接。

该方式无需系统权限,适用于大多数应用。

回到顶部