Flutter 鸿蒙项目 Android Studio 点击 Run 失败 ohpm 缺失

背景

把 Flutter 项目接到鸿蒙(OpenHarmony)后,经常遇到一件怪事:

  • 命令行 flutter run 能秒装秒跑;
  • 回到 Android Studio,点绿色 ▶️ 却立刻报错,终端里要么提示找不到 ohpm,要么甩出 hvigor ERROR: 00303168 SDK component missing.

这篇文章把踩坑、定位、解决的全过程记录下来,按图索骥,五分钟就能搞定。


一、现象还原

  1. 设备已识别,flutter devices 能看到 33Z0224620023870 (ohos-arm64)
  2. 命令行运行正常,桌面图标正常出现。
  3. Android Studio 的 Run 窗口几乎瞬间退出,两条错误轮流出现:
    • ProcessException: Failed to find "ohpm"
    • hvigor ERROR: 00303168 Configuration Error -- SDK component missing.

二、原因

报错 根因 为什么 CLI 能跑
找不到 ohpm Android Studio 启动的进程读不到 .bashrc / .zshrc 里的 PATH 你在终端里 export 过,命令行继承到了
SDK 组件缺失 DevEco Studio 的 HarmonyOS SDK 不完整 你之前用 ./hvigorw --sync 下载过,但 Android Studio 没同步到路径

三、解决步骤

1 把 ohpm 写进系统 PATH

Windows

  1. 复制路径:C:\Program Files\Huawei\DevEco Studio\tools\ohpm\bin
  2. Win + S → 编辑系统环境变量 → 系统变量 → Path → 新建 → 粘贴 → 确定
  3. 打开新的 PowerShell,输入 ohpm -v,看到版本号即可

macOS / Linux

bash 复制代码
# 默认路径,按实际安装位置调整
sudo sh -c 'echo "/Applications/DevEco-Studio.app/Contents/tools/ohpm/bin" > /etc/paths.d/devstudio'
exec $SHELL
ohpm -v
2 补全 HarmonyOS SDK

图形界面(最稳)

  1. 打开 DevEco Studio → Tools → SDK Manager → HarmonyOS
  2. 勾选对应 API 版本(例如 API 9)+ hvigor + ohpm + toolchains → Apply
  3. 下载完重启 Android Studio

命令行(无界面场景)

bash 复制代码
./hvigorw --sync --no-daemon      # macOS / Linux
hvigorw.bat --sync --no-daemon    # Windows
3 校验环境变量

MAC电脑可以直接拷贝:

bash 复制代码
# 国内镜像
export PUB_HOSTED_URL=https://pub.flutter-io.cn
export FLUTTER_STORAGE_BASE_URL=https://storage.flutter-io.cn

# 拉取下来的flutter_flutter/bin目录
export PATH=/Users/admin/ohos/flutter_flutter/bin:$PATH

# OpenHarmony SDK
export TOOL_HOME=/Applications/DevEco-Studio.app/Contents # mac环境
export DEVECO_SDK_HOME=$TOOL_HOME/sdk # command-line-tools/sdk
export PATH=$TOOL_HOME/tools/ohpm/bin:$PATH # command-line-tools/ohpm/bin
export PATH=$TOOL_HOME/tools/hvigor/bin:$PATH # command-line-tools/hvigor/bin
export PATH=$TOOL_HOME/tools/node/bin:$PATH # command-line-tools/tool/node/bin
export HDC_HOME=$TOOL_HOME/sdk/default/openharmony/toolchains # hdc指令(可选)

# 可选配置项(使用Android Studio 或者 Visual Studio Code调试时需要配置此项,jdk版本为17.0.12)
JAVA_HOME=/Users/admin/Documents/JDK/jdk-17.0.12.jdk/Contents/Home
PATH=$JAVA_HOME/bin:$PATH:.
export JAVA_HOME
export PATH

# 可选配置项(防止由于Flutter OpenHarmony版的git下载地址环境变量不匹配,影响后续的flutter项目创建)
export FLUTTER_GIT_URL=https://gitee.com/openharmony-sig/flutter_flutter.git

# 非必选配置项(若command-line-tools目录下的tool文件里存在node环境,则无需配置,若无则可进行如下单独配置)
# export NODE_HOME=/Users/admin/node/node-18.14.1
# export PATH=$PATH:$NODE_HOME/bin
4 验证
bash 复制代码
hvigorw --version
# 正常输出版本号即环境 OK

回到 Android Studio 点 Run,hap 编译一路绿色,真机秒开。


四、常见疑问

Q1 : 我在 .zshrc 里 export 过 PATH,为什么还是找不到?
A : macOS 的 GUI 程序不读 shell rc,必须写 /etc/paths.d/*/etc/environment

Q2 : DevEco Studio 下载 SDK 时提示网络失败?
A : 配个国内镜像,Settings → HTTP Proxymirrors.huaweicloud.com

Q3 : 项目里 local.properties 多了一行 harmonyos.sdk 指向错误路径?
A: 直接删掉,让 hvigor 用 DevEco 安装目录下的 SDK。


五、一句话总结

CLI 能跑不代表 IDE 能跑,PATH 和 SDK 必须系统级可见;两步补齐,Android Studio 的 ▶️ 就能和 flutter run 一样丝滑。


六、参考链接

如果本文帮到了你,点个赞或转给还在踩坑的同伴吧!

相关推荐
我命由我1234510 小时前
Bugly - Bugly 基本使用( App 质量追踪平台)
android·java·java-ee·android studio·android jetpack·android-studio·android runtime
程序员老刘11 小时前
Dart 3.12 更新要点:乏善可陈
flutter·ai编程·dart
largecode11 小时前
座机号码认证如何操作?申请热线实名名片,树立统一官方客服形象
linux·sql·华为·c#·.net·wpf·harmonyos
大雷神11 小时前
第07篇|权限分层策略:相机、定位、生物认证、手势为什么分开申请
harmonyos
●VON12 小时前
鸿蒙Flutter实战:水平滑动分类标签筛选栏
flutter·华为·harmonyos
小成Coder14 小时前
【Jack实战】如何用 Share Kit 接入碰一碰和 AI 隔空传送
华为·harmonyos·鸿蒙
●VON14 小时前
鸿蒙Flutter实战:24小时新建标签提示组件
android·flutter·华为·harmonyos·鸿蒙
●VON14 小时前
鸿蒙Flutter实战:MultiProvider多状态管理架构实践
flutter·华为·架构·harmonyos·鸿蒙
不羁的木木15 小时前
HarmonyOS防窥保护实战:3步接入Device Security Kit保护用户隐私
华为·harmonyos