惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

D
Docker
P
Palo Alto Networks Blog
S
Secure Thoughts
V2EX - 技术
V2EX - 技术
Vercel News
Vercel News
人人都是产品经理
人人都是产品经理
S
SegmentFault 最新的问题
F
Full Disclosure
WordPress大学
WordPress大学
Martin Fowler
Martin Fowler
B
Blog RSS Feed
I
InfoQ
博客园 - 叶小钗
Google Online Security Blog
Google Online Security Blog
L
LangChain Blog
M
MIT News - Artificial intelligence
T
Troy Hunt's Blog
L
LINUX DO - 最新话题
Webroot Blog
Webroot Blog
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
小众软件
小众软件
Microsoft Azure Blog
Microsoft Azure Blog
SecWiki News
SecWiki News
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
P
Proofpoint News Feed
Schneier on Security
Schneier on Security
罗磊的独立博客
T
The Exploit Database - CXSecurity.com
T
The Blog of Author Tim Ferriss
Hacker News: Ask HN
Hacker News: Ask HN
Hacker News - Newest:
Hacker News - Newest: "LLM"
P
Privacy & Cybersecurity Law Blog
Forbes - Security
Forbes - Security
博客园 - 三生石上(FineUI控件)
Application and Cybersecurity Blog
Application and Cybersecurity Blog
cs.CV updates on arXiv.org
cs.CV updates on arXiv.org
W
WeLiveSecurity
Security Archives - TechRepublic
Security Archives - TechRepublic
L
LINUX DO - 热门话题
Cyberwarzone
Cyberwarzone
Scott Helme
Scott Helme
T
Tor Project blog
Help Net Security
Help Net Security
I
Intezer
T
Tenable Blog
博客园 - 司徒正美
AI
AI
博客园 - Franky
云风的 BLOG
云风的 BLOG
H
Heimdal Security Blog

人人都是产品经理

为什么你的产品找不到差异化?90%的失败都卡在第一步上(下) – 人人都是产品经理, 3年从30万到1300万用户、获2200万美元融资,这个AI教育产品用“抽卡”破解了获客难题 – 人人都是产品经理, 园区招商系统怎么做才能真正帮到去化?我加了这一个功能,推广链接转发400次阅读过万 – 人人都是产品经理, AI大事件:OpenAI发完网络安全模型又搞药物研发,小鹏汽车要抓”DeepSeek时刻” – 人人都是产品经理, 电商不是卖货,是一场更残酷的产品经理实战 – 人人都是产品经理, 没想到,活动营销又回来了! – 人人都是产品经理, 为何All-in海外KOC:一场关于AI时代窗口期的豪赌 – 人人都是产品经理, 重新理解企业的内部协作 – 人人都是产品经理, 苹果的 AI 战略到底是什么? – 人人都是产品经理, 医疗智能体·第2讲——合规护城河:等保、PIPL与HIPAA的架构实战 – 人人都是产品经理, 向量知识库五步法:从“答非所问”到“精准回复” – 人人都是产品经理, 鸿蒙PC三方库构建总指挥HPKBUILD(sha)库为例 – 人人都是产品经理, 何时该用LLM?AI产品经理的LLM设计指南 – 人人都是产品经理, 医疗信息领域的需求方、决策方、准入方以及关注点(二) – 人人都是产品经理, 即梦涨价:一场被误读的「傲慢」 – 人人都是产品经理, 面试AI PM必答题:Hermes和OpenClaw的区别,如何讲清楚业务价值 – 人人都是产品经理, AI的下一张船票:世界模型——AI产品经理必须理解的技术拐点 – 人人都是产品经理, 小红书做GEO,怎么让AI信你?记住这 3 个重要信息 – 人人都是产品经理, 5 家印度 AI 初创公司,看看印度 AI 再做什么 – 人人都是产品经理, AI项目跨团队协作:产品技术业务如何不打架 – 人人都是产品经理, Agentic Workflow(智能体工作流):让AI从”答案生成器”变成”数字员工” – 人人都是产品经理, lycium_plusplus 项目全景解读:OpenHarmony 三方库构建的“大管家” – 人人都是产品经理, 从爆单救火到前置履约:两套预采策略,把生鲜大促履约效率拉满 – 人人都是产品经理, 什么时候该补货?我用一轮数据做了一个决定 – 人人都是产品经理, 从“机械兜底”到“动态分流”:AI客服重复进线治理的4大底层逻辑 – 人人都是产品经理, 抖音拼效率,红书拼洞察 – 人人都是产品经理, 全民狂欢与退潮——为什么龙虾这波热潮冷却得如此之快? – 人人都是产品经理, Stripe押注!MPP重塑全球支付 – 人人都是产品经理, 小红书GEO:AI引用你的内容,不是因为你对,而是因为你看起来可信 – 人人都是产品经理, 前百度副总裁押注办公Agent,日韩付费爆发,Manus迎来强劲对手 – 人人都是产品经理, 企事业单位数字化的业务供需本质 – 人人都是产品经理, 医疗智能体·第1讲——医疗信息化重构:从“辅助软件”到“自主智能体”的范式转移 – 人人都是产品经理, 粉丝量就是空气!!! – 人人都是产品经理, 用户说“薯片碎了”,机器回“要买吗?”:意图识别的翻车与破局 – 人人都是产品经理, RAG召回准确率从75到90 我做对了这三件事 – 人人都是产品经理, AI大事件:Anthropic改收费、OpenAI发安全版、手术机器人纳入医保、阿里发布”秒悟” – 人人都是产品经理, Chrome 推出 Skills 新功能,Agent 重塑上网方式 – 人人都是产品经理, GitHub前创始人拿了a16z的1700万美元,做Agent时代的Git – 人人都是产品经理 拷贝或克隆其他 Flutter OH 项目到本地后无法运行 – 人人都是产品经理, 优惠券设计:优惠券创建 – 人人都是产品经理, 不用死磕文档!AI 助手 1 小时搞定飞书 CLI 安装 + 配置 + 知识库 – 人人都是产品经理, 用小龙虾做竞品分析报告:从2天到20分钟,我是怎么做到的 – 人人都是产品经理 用小龙虾做市场分析报告:搞懂这3个公式,市场规模不再靠猜 – 人人都是产品经理, 你早就在做 Harness 工程,只是不知道它叫这个名字 – 人人都是产品经理, Think Long就够?你可能想多了! – 人人都是产品经理, 货代SRM实战:供应商准入怎么做,才能让资源池不是通讯录而是可交付网络? – 人人都是产品经理, 如何做好用户调研?详解基本技巧 – 人人都是产品经理, 木鸟、途家、美团对打,平台春天行动开“卷” – 人人都是产品经理, 入职才发现公司不靠谱?小红书从业者求职避坑指南 – 人人都是产品经理, 美国 AI 三巨头联手封堵,中国 AI 突围之路在何方 – 人人都是产品经理, 小红书,放在需求对面的镜子 – 人人都是产品经理, AI 会带来大规模失业吗? – 人人都是产品经理, 从出单到补货前,我第一次犹豫:该不该放大? – 人人都是产品经理, Flutter 三方库鸿蒙化适配:5 种高效检查方式,快速判断是否需要适配 – 人人都是产品经理, 从做产品进阶拿结果:医美机构产品经理转岗科室运营经理 – 人人都是产品经理, 阿里HappyHorse,一场关于“Token经济”的阳谋 – 人人都是产品经理, To B AI:客户留存落地的观察与思考 – 人人都是产品经理, AI产品的“生命线”——数据采集、标注、清洗的产品化设计 – 人人都是产品经理, 谈谈AI Agent(二):当“孩子”能自己“体验世界”时,你该学什么? – 人人都是产品经理, UI/UX设计师的3层能力进阶,前两层让你活下来,第三层…才是真正的分水岭 – 人人都是产品经理, 2分钟 → 30秒,效率提升75%:B端产品经理如何用「规则枷锁」驯服AI幻觉? – 人人都是产品经理, 还没来得及学OpenClaw,来了个更猛的:Hermes Agent – 人人都是产品经理, AI日报:宇树机器人跑出10m/s刷新世界纪录 – 人人都是产品经理, 一文说透基金互金如何用情绪价值引导用户决策做转化 – 人人都是产品经理, 当浏览器开始替你”看”网页:AI 浏览器正在亲手拆掉它脚下的那张网 – 人人都是产品经理, 0代码,一天时间我Vibe Coding了个网站 – 人人都是产品经理, Hermes 和 OpenClaw 之争,Agent 的能力应该“装上去”还是“长出来”? – 人人都是产品经理 视频生成的“桌子”,字节Seedance 2掀完,阿里快乐马掀 – 人人都是产品经理, 从听不懂到完全信任:我的 Codex 深度产品体验 – 人人都是产品经理, 当虚拟偶像有了北京户口,与真人偶像还有什么区别? – 人人都是产品经理, 会说,远远比会做更重要 —— 对 SBTI 爆火现象的五层观察 – 人人都是产品经理, AI产品经理必看:当“搭环境”比“选模型”更重要,你的认知还在2024年吗? – 人人都是产品经理, 2026年AI产品商业化核心逻辑:从功能demo到规模化营收的3个必破卡点 – 人人都是产品经理, 京东围绕供应链,卷起裤腿下场的那些事儿 – 人人都是产品经理, SBTI一夜刷屏:它赢在了“太会说人话” – 人人都是产品经理, 折扣零售的真相:不是便宜,而是价值感! – 人人都是产品经理, 和甲方吵了一架,最后加钱做了——我学到的ToB产品经理生存法则 – 人人都是产品经理, 和几位小红书操盘手聊了8小时,干货全在这 – 人人都是产品经理, 智谱GLM-5.1登场,开源模型首超Opus4.6!!! – 人人都是产品经理 Anthropic收入凭什么反超OpenAI,终于有人把这事说清楚了 – 人人都是产品经理, 史上最有故事感的技术报告——Claude最强模型Mythos 7个极其精彩的细节 – 人人都是产品经理, 模型不是壁垒,Harness 也不是 – 人人都是产品经理, 抖音本地生活业务思考21 – 人人都是产品经理, Superpowers:145k Star的AI编码框架,到底是什么来头? Superpowers:145k Star的AI编码框架,到底是什么来头? – 人人都是产品经理, OpenAI 的路走错了,Anthropic Harness 解法启示:模型需要实践专科生 – 人人都是产品经理, 画原型图的前一步:设计站点地图 – 人人都是产品经理, 给 DeepSeek 的最后一封催更信 – 人人都是产品经理, 手把手教你用 Claude Code 搭建 AI 营销团队:5 个 Agent、12 项技能,独立完成研究、写作、设计全流程 – 人人都是产品经理, 你以为大模型在学语言?不,它在重新发明语言学 – 人人都是产品经理 所谓Skill,不过是AI时代的工业垃圾 – 人人都是产品经理, 聊一聊内容传播的几个方法 – 人人都是产品经理, 当平台开始吃掉生态:从 OpenClaw 被封杀,读懂 Anthropic 的这盘棋 – 人人都是产品经理, 你装了 10 个 AI 插件,Obsidian 还是一个文件夹 – 人人都是产品经理 关于AI智能体架构演进的系统性思考:从单体试水到多体协同的重构 – 人人都是产品经理, 当“人”变成Skill,我们又该何去何从? – 人人都是产品经理 Mythos 事件:前沿 AI 治理的意外实验 – 人人都是产品经理, 货代CRM:信用与风险管理怎么做,才能把坏账风险拦在放货之前? – 人人都是产品经理, 从HR收集自拍照到员工自助录入——我见证了园区人脸识别从”不可用”到”真好用”的全过程 – 人人都是产品经理 千问闯关AI混沌期:阿里画靶,吴嘉张弓,马云射箭? – 人人都是产品经理,
CodeArts 开发 Flutter-OH 退出 APP 插件
nutpi · 2026-02-27 · via 人人都是产品经理

以flutter_exit_app为例,展示了从项目结构分析、MethodChannel通信机制理解,到核心难点AbilityAware接口获取UIAbilityContext及调用terminateSelf()退出的全流程。本文详解如何利用华为云码道(CodeArts)代码智能体,高效完成Flutter插件的OpenHarmony平台适配。

使用华为云码道(CodeArts)代码智能体开发 Flutter-OH 退出插件全流程

一、背景介绍

随着鸿蒙系统(HarmonyOS)的快速发展,越来越多的 Flutter 插件需要适配 OpenHarmony 平台。本文将详细介绍如何使用华为云码道(CodeArts)代码智能体,为现有的 Flutter 插件添加 OpenHarmony 平台支持。

以 flutter_exit_app 插件为例,该插件提供了跨平台的应用退出功能,原本支持 Android 和 iOS 平台,我们需要为其添加 OpenHarmony 平台的支持。

二、开发环境

在开始之前,请确保已准备好以下开发环境:

三、项目结构分析

3.1 原有项目结构

flutter_exit_app/
├── lib/

└── flutter_exit_app.dart  # Dart 端接口
├── android/                  # Android 平台实现
├── ios/                        # iOS 平台实现
├── example/                 # 示例应用
└── pubspec.yaml           # 项目配置

3.2 需要添加的 OpenHarmony 结构

image-20260214112733231

flutter_exit_app/
├── ohos/           # OpenHarmony 平台实现
│   ├── src/main/
│   │   ├── ets/components/plugin/
│   │   │   └── FlutterExitAppPlugin.ets  # 插件核心实现
│   │   └── module.json5
│   ├── index.ets
│   ├── oh-package.json5
│   └── build-profile.json5
├── example/ohos/         # 示例应用 OpenHarmony 工程
└── README.OpenHarmony.md          # OpenHarmony 平台文档

四、开发流程

4.1 第一步:分析需求

下发指令 flutter create . –template=plugin –platforms=ohos ,初步生成

4.1 第二步:运行调试报错处理

向 CodeArts 代码智能体描述需求:

点击退出按钮,应用没有正确退出,请检查 FlutterExitAppPlugin.ets 文件

代码智能体会自动分析问题并给出解决方案。

4.3 第三步:理解 Flutter 与 OpenHarmony 通信机制

Flutter 与原生平台的通信通过 MethodChannel 实现:

Dart 端(Flutter):

static Future<bool> exitApp({bool iosForceExit = false}) async {
  try {
    final String? res = await channel.invokeMethod<String>(
      ChannelName.exitApp,  // ‘com.laoitdev.exit.app’
      <String, dynamic>{“killIosProcess”: iosForceExit},
    );
    return res == “Done”;
  } on PlatformException {
    return false;
  }
}

OpenHarmony 端(ArkTS):

onMethodCall(call: MethodCall, result: MethodResult): void {
  if (call.method == “com.laoitdev.exit.app”) {
    // 处理退出逻辑
  }
}

4.4 第四步:实现插件核心功能问题诊断

初次实现时,代码智能体发现了一个关键问题:

// 错误实现
this.context = binding.getApplicationContext() as common.UIAbilityContext

getApplicationContext() 返回的是 common.Context 类型,而不是 UIAbilityContext。只有 UIAbilityContext 才有 terminateSelf() 方法。

正确实现方案

代码智能体建议使用 AbilityAware 接口来正确获取 UIAbilityContext:

import {
  FlutterPlugin,
  FlutterPluginBinding,
  MethodCall,
  MethodCallHandler,
  MethodChannel,
  MethodResult,} from’@ohos/flutter_ohos’;
import { AbilityAware, AbilityPluginBinding } from’@ohos/flutter_ohos’;
import { common, UIAbility } from’@kit.AbilityKit’;
import { BusinessError } from’@kit.BasicServicesKit’;

exportdefaultclass FlutterExitAppPlugin
implements FlutterPlugin, MethodCallHandler, AbilityAware {

private channel: MethodChannel | null = null;
privatestatic _uiContext: common.UIAbilityContext | null = null;

// 通过 AbilityAware 接口获取 UIAbilityContext
  onAttachedToAbility(binding: AbilityPluginBinding): void {
    FlutterExitAppPlugin._uiContext = binding.getAbility().context;
  }

  onMethodCall(call: MethodCall, result: MethodResult): void {
    if (call.method == “com.laoitdev.exit.app”) {
      if (FlutterExitAppPlugin._uiContext) {
        try {
          FlutterExitAppPlugin._uiContext.terminateSelf()
            .then(() => {
              console.info(‘terminateSelf succeed’);
              result.success(“Done”);
            })
            .catch((err: BusinessError) => {
              console.error(`terminateSelf failed: ${err.message}`);
              result.error(“TERMINATE_FAILED”, err.message, null);
            });
        } catch (err) {
          result.error(“TERMINATE_ERROR”, `Error: ${err.message}`, null);
        }
      }
 else {
        result.error(“CONTEXT_NULL”, “UIContext is null”, null);
      }
    }
  }
}

4.5 第五步:配置 pubspec.yaml

在 pubspec.yaml 中添加 OpenHarmony 平台配置:

flutter:
  plugin:
    platforms:
      android:
        package:com.laoitdev.lib.exit.app.flutter_exit_app
        pluginClass:FlutterExitAppPlugin
      ios:
        pluginClass:FlutterExitAppPlugin
      ohos:
        pluginClass:FlutterExitAppPlugin
        package:com.laoitdev.lib.exit.app.flutter_exit_app

4.6 第六步:创建 README 文档

使用代码智能体生成 OpenHarmony 平台的 README 文档:

README.OpenHarmony_CN.md(中文版):

## 1. 安装与使用
dependencies:
flutter_exit_app:
git:url: “git@gitcode.com:oh-flutter/flutter_exit_app.git”
path: “.”
## 2. 兼容性
– Flutter: 3.35.8-ohos-0.0.2
– SDK: 5.1.0(18)
– IDE: DevEco Studio: 6.1.0
– ROM: 6.1.0.28(SP12)
## 3. API
| 方法                             | 说明         |
| ——————————– | ———— |
| `FlutterExitApp.exitApp()`       | 退出应用     |
| `FlutterExitApp.platformVersion` | 获取平台版本 |

4.7 第七步:获取环境信息

代码智能体可以自动获取本地环境信息:

# 获取 Flutter 版本
flutter –version
# 输出: Flutter 3.35.8-ohos-0.0.2
# 获取 DevEco Studio 版本
defaults read /Applications/DevEco-Studio.app/Contents/Info CFBundleShortVersionString
# 输出: 6.1.0
# 获取设备 ROM 版本
hdc shell param get const.product.software.version
# 输出: ALN-AL00 6.1.0.28(SP12C00E28R4P7log)

4.8 第八步:提交代码

使用代码智能体执行 Git 操作:

image-20260214112639787

# 添加文件
git add README.OpenHarmony_CN.md README.OpenHarmony.md pubspec.yaml ohos example/ohos
# 提交
git commit -m “feat: add OpenHarmony platform support”
# 推送
git push origin main

五、关键技术点总结

5.1 AbilityAware 接口

AbilityAware 是 OpenHarmony Flutter 插件开发中的重要接口,用于监听 Ability 生命周期:

interface AbilityAware {
  onAttachedToAbility(binding: AbilityPluginBinding): void;
  onDetachedFromAbility(): void;
}

通过这个接口可以安全地获取 UIAbilityContext,避免类型转换错误。

5.2 terminateSelf() 方法

terminateSelf() 是 OpenHarmony 中关闭 Ability 的标准方法:

abilityContext.terminateSelf()
  .then(() => {
    // 成功关闭
  })
  .catch((err: BusinessError) => {
    // 处理错误  });

5.3 MethodChannel 通信

Flutter 与原生平台的通信流程:

Flutter (Dart)
    ↓ invokeMethod()
MethodChannel
    ↓ onMethodCall()
OpenHarmony (ArkTS)
    ↓ terminateSelf()
系统关闭应用

六、CodeArts 代码智能体的优势

6.1 智能问题诊断

代码智能体能够快速定位问题根源,例如:

  • 识别 Context 类型转换错误
  • 发现未初始化的变量
  • 检测 API 使用不当

6.2 自动化操作

代码智能体可以执行多种自动化操作:

  • 获取系统环境信息
  • 执行 Git 命令
  • 生成文档模板
  • 代码重构

6.3 知识库支持

代码智能体内置了丰富的 OpenHarmony 开发知识:

  • Flutter 插件开发规范
  • HarmonyOS API 文档
  • 最佳实践指南

七、测试验证

7.1 功能测试运行

示例应用点击 “Exit” 按钮验证应用正确退出

7.2 兼容性测试

在以下环境测试通过:

八、总结

通过华为云码道(CodeArts)代码智能体,我们高效地完成了 Flutter 插件的 OpenHarmony 平台适配工作。

整个过程包括:

  • 需求分析 – 明确插件功能需求
  • 问题诊断 – 识别代码中的问题
  • 方案实现 – 编写正确的实现代码
  • 文档编写 – 生成 README 文档
  • 环境配置 – 获取并配置开发环境信息
  • 代码提交 – 完成版本控制操作

代码智能体大大提高了开发效率,让开发者能够专注于核心业务逻辑,而无需花费大量时间在环境配置、文档编写等重复性工作上。

image-20260214112912292

九、参考资料

Flutter 官方文档[1]OpenHarmony 开发文档

[2]华为云码道 CodeArts

[3]flutter_exit_app 原项目

[4]适配后的项目地址

本文由人人都是产品经理作者【nutpi】,微信公众号:【nutpi】,原创/授权 发布于人人都是产品经理,未经许可,禁止转载。

题图来自Unsplash,基于 CC0 协议。