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 能跑
找不到 ohpmAndroid 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

# 默认路径,按实际安装位置调整
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

命令行(无界面场景)

./hvigorw --sync --no-daemon      # macOS / Linux
hvigorw.bat --sync --no-daemon    # Windows
3 校验环境变量

MAC电脑可以直接拷贝:


# 国内镜像
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 验证
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 一样丝滑。


六、参考链接

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

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值