flutter build hap --release` 后版本号被改回 1.0.0

flutter build hap --release 后版本号被改回 1.0.0?

欢迎大家加入开源鸿蒙跨平台开发者社区

背景

在工程里改好了鸿蒙侧应用版本(常见位置是 ohos/AppScope/app.json5 ;部分文档或工具里也会口语说成 app.json),其中的 版本名称 (对应 version 里的 name)是你期望的值。随后执行:

bash 复制代码
flutter build hap --release

出包后再打开同一份配置文件,发现版本又被写回 1.0.0 (或与 pubspec.yaml 里一致的基础版本)。

现象

  • 手动改的 版本名 / 版本号 在 Release 构建后丢失或被覆盖。
  • 反复构建时,版本似乎总跟着某处「默认来源」走,而不是保留你在 OH 工程里的手工编辑。

原因(机制说明)

当前 Flutter OpenHarmony 出包流程里,构建会用 pubspec.yaml 中的 version(以及可选的构建参数)去同步/写回鸿蒙应用配置 ,而不是以「仅存在于 app.json5 里、且未在 Dart 侧声明」的修改为准。

因此:

  • pubspec.yaml 仍是默认的 version: 1.0.0+1 之类,构建后 OH 侧展示版本很容易被同步成 1.0.0
  • 只改 app.json5、不改 pubspec.yaml 也不在命令行指定版本时,下一次 flutter build hap 仍可能按上述规则覆盖,看起来像「字段被重置」。

解决办法

1. 在 pubspec.yaml 中维护版本(推荐日常开发)

与 Android/iOS 习惯一致,在根目录 pubspec.yaml 中写:

yaml 复制代码
version: 4.0.3+10000

版本名+版本号+ 后为 versionCode 类递增数字)。再执行 flutter build hap,构建产物会与之一致,避免和手工改 OH 文件「打架」。

2. 构建命令行临时指定(适合 CI / 单次出包)

不改文件时,可在构建时显式传入:

bash 复制代码
flutter build hap --release --build-name=4.0.3 --build-number=10000
  • --build-name:对应对外展示的版本名称(如 4.0.3)。
  • --build-number:对应递增的构建号 / 数字版本(如 10000)。

流水线里建议固定用同一套规则(读环境变量或标签)传入这两个参数,避免每次本地默认值覆盖。

3. 不要依赖「只改 OH 目录、不改 Dart 工程版本」

若团队规范是「以 Flutter 工程为准」,应把 唯一真相源 放在 pubspec.yaml 或 CI 传入的 --build-name / --build-number,而不是只改 app.json5

小结

做法 说明
pubspec.yamlversion flutter build hap 默认逻辑一致,推荐
使用 --build-name / --build-number 适合脚本与发布流水线
只改 ohos/AppScope/app.json5 易被后续构建覆盖,需配合上述其一

参考命令:

bash 复制代码
flutter build hap --release --build-name=4.0.3 --build-number=10000
相关推荐
weixin_443478513 小时前
Flutter 中Google 地图组件包 `google_maps_flutter
flutter
麒麟ZHAO4 小时前
鸿蒙flutter第三方库适配 - 动态表单
flutter·华为·harmonyos
见山是山-见水是水5 小时前
鸿蒙flutter第三方库适配 - 页面转场应用
flutter·华为·harmonyos
恋猫de小郭5 小时前
Flutter PC 多窗口最新进展,底层原生窗口句柄支持已合并
android·前端·flutter
见山是山-见水是水6 小时前
鸿蒙flutter第三方库适配 - 主题切换应用
flutter·华为·harmonyos
牛马1116 小时前
Flutter BoxDecoration boxShadow 完整用法
flutter
见山是山-见水是水7 小时前
鸿蒙flutter第三方库适配 - 多语言应用
flutter·华为·harmonyos
麒麟ZHAO7 小时前
Flutter 框架跨平台鸿蒙开发 - 匿名真心话
flutter·华为·harmonyos
langyuejing7 小时前
Flutter 原生能力集成指南
flutter