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
相关推荐
神奇的程序员13 小时前
开发了一个管理本地开发环境的软件
前端·flutter
xmdy586614 小时前
Flutter+开源鸿蒙实战|智联邻里Day9 系统权限适配+应用全局分享+缓存深度优化+版本更新弹窗
flutter·开源·harmonyos
maaath18 小时前
【maaath】Flutter for OpenHarmony 乐器学习应用开发实战
flutter·华为·harmonyos
maaath1 天前
【maaath】 Flutter for OpenHarmony 实战:电池优化应用开发指南
flutter·华为·harmonyos
勤劳打代码1 天前
Flutter 架构日记 —— 可演进的 Flutter Dialog 组件
flutter·架构
Eric_HYD1 天前
Flutter 字体字生效原理解析
flutter
maaath1 天前
【无标题】Flutter for OpenHarmony 的文具手账应用开发实践
flutter·华为·harmonyos
里欧跑得慢1 天前
Flutter 主题管理:构建一致的用户界面
前端·css·flutter·web
liulian09162 天前
Flutter for OpenHarmony 跨平台开发:单位转换功能实战指南
flutter
千码君20162 天前
Trae:一些关于flutter和 go前后端开发构建的分享
android·flutter·gradle·android-studio·trae·vibe code