145 Star 1.4K Fork 1.7K

OpenHarmony/applications_app_samples

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
贡献代码
同步代码
取消
提示: 由于 Git 不支持空文件夾,创建文件夹后会生成空的 .keep 文件
Loading...
README

应用故障恢复

介绍

本示例展示了在应用中如何适配故障恢复相关接口。

样例包含以下场景:
一.单Ability自动恢复
在EntryAbility的故障触发页面触发故障,自动重启回到故障触发页面。

二.多Ability自动恢复
应用中启动了EntryAbility和SecondAbility,在第二个启动的SecondAbility的故障触发页面触发故障。
自动重启到SecondAbility的故障触发页面。
从任务管理中将EntryAbility切回前台,预期能回到故障触发页面,并恢复页面上点击次数信息。

三.多Ability主动恢复
应用中启动了EntryAbility和SecondAbility,在第二个启动的SecondAbility的故障触发页面触发故障。
重启时启动RecoveryAbility,让使用者选择具体启动的Ability。

四.Ability后台强制终止恢复
应用中启动了EntryAbility和SecondAbility,并切入后台。
系统回收该应用,再次拉起时能够恢复先前的状态。

相关概念:
故障:指的是应用处于无法提供服务的状态,如卡死以及崩溃。
系统强制终止:指的是由于系统或者应用的原因,系统强制终止正在运行的应用进程,并回收资源的操作。

效果预览

首页 故障触发页面
home fault

使用说明

一.单Ability自动恢复
点击首页点击跳转到故障触发页面
在故障触发页面点击按钮点击,再点击保存当前Ability状态以及触发JsError
以上场景预期:
能够回到故障触发页面页面,页面上的点击次数与触发保存状态时的一致。

二.多Ability自动恢复
点击首页点击跳转到故障触发页面
故障触发页面点击启动SecondAbility 点击首页点击跳转到故障触发页面
在故障触发页面点击按钮点击,再点击保存当前Ability状态以及触发JsError
以上场景预期:
立即回到SecondAbility的故障触发页面,并恢复页面的点击次数信息。
从任务管理中将EntryAbility切回前台,预期能回到故障触发页面,页面上的点击次数与触发保存状态时的一致。

三.多Ability主动恢复
点击首页点击跳转到故障触发页面
故障触发页面点击启动SecondAbility 在SecondAbility的故障触发页面点击设置重启Ability。
在SecondAbility的故障触发页面点击触发JsError
以上场景预期:
重启时启动RecoveryAbility。

四.Ability后台强制终止恢复
点击首页点击跳转到故障触发页面
故障触发页面点击启动SecondAbility 在SecondAbility的故障触发页面点击Counter,点击保存当前Ability状态,并切入后台
使用kill命令强制终止当前应用
以上场景预期:
从任务管理中将EntryAbility切回前台,预期能回到故障触发页面,并恢复页面上的点击次数信息。
从任务管理中将SecondAbility切回前台,预期能回到故障触发页面,并恢复页面上的点击次数信息。

为避免反复拉起,两次测试的间隔至少为60秒(自动拉起的间隔为60秒)。

工程目录

entry/src/main/
├── cpp                      // 触发Native卡死代码
│   ├── CMakeLists.txt
│   ├── hello.cpp
│   └── types
│       └── libentry
│           ├── index.d.ts
│           └── oh-package.json5
├── ets
│   ├── ability
│   │   ├── EntryAbility.ets  // 测试入口Ability
│   │   ├── RecoveryAbility.ets // 恢复引导Ability
│   │   └── SecondAbility.ets // 测试第二Ability
│   ├── app
│   │   └── MyAbilityStage.ets // 用于初始化appRecovery的配置
│   ├── common
│   │   ├── Logger.ts  // 日志
│   │   └── TitleBar.ets // 标题
│   └── pages
│       ├── FaultTriggerPage.ets // 故障触发页面
│       ├── Index.ets // 首页
│       └── RecoveryPage.ets // 恢复页面

具体实现

  • 使能应用恢复功能,源码参考:MyAbilityStage.ets
  • 配置支持恢复的Ability,源码参考:module.json5
    • Ability的节点中增加recoverable的配置,并设置为true
  • 实现恢复功能,源码参考:EntryAbility.ets
    • onSaveState中保存用于恢复的数据
    • onCreatewant参数中恢复所需要的数据

相关权限

不涉及

依赖

约束与限制

1.本示例仅支持标准系统上运行,支持设备:RK3568。

2.本示例为Stage模型,支持API10版本SDK,SDK版本号(API Version 10 Release),镜像版本号(4.0 Release)

3.本示例需要使用DevEco Studio 版本号(4.0 Release)及以上版本才可编译运行。

下载

给出单独下载本工程的命令,在代码中替换工程目录并以/结尾,如下面示例中的 code/BasicFeature/DFX/AppRecovery/,示例如下:

如需单独下载本工程,执行如下命令:

git init
git config core.sparsecheckout true
echo code/BasicFeature/DFX/AppRecovery/ > .git/info/sparse-checkout
git remote add origin https://gitee.com/openharmony/applications_app_samples.git
git pull origin master
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/openharmony/applications_app_samples.git
git@gitee.com:openharmony/applications_app_samples.git
openharmony
applications_app_samples
applications_app_samples
master

搜索帮助