component-startup-rules-fa.md 2.5 KB
Newer Older
H
HuangXW 已提交
1
# 组件启动规则(FA模型)
2 3 4 5 6


启动组件是指一切启动或连接应用组件的行为:


H
HuangXW 已提交
7
- 启动PageAbility、ServiceAbility,如使用startAbility()等相关接口。
8

H
HuangXW 已提交
9
- 连接ServiceAbility、DataAbility,如使用connectAbility()、acquireDataAbilityHelper()等相关接口。
10 11 12 13 14 15 16 17 18 19 20 21 22 23 24


在OpenHarmony中,为了保证用户具有更好的使用体验,对以下几种易影响用户体验与系统安全的行为做了限制:


- 后台应用任意弹框,如各种广告弹窗,影响用户使用。

- 后台应用相互唤醒,不合理的占用系统资源,导致系统功耗增加或系统卡顿。

- 前台应用任意跳转至其他应用,如随意跳转到其他应用的支付页面,存在安全风险。


鉴于此,OpenHarmony制订了一套组件启动规则,主要包括:


H
HuangXW 已提交
25 26
- **跨应用启动组件,需校验目标组件Visible**
  - 只针对跨应用场景
27 28
  - 若目标组件exported字段配置为false,则需校验`ohos.permission.START_INVISIBLE_ABILITY`权限
  - [组件exported配置参考](../quick-start/module-configuration-file.md#abilities标签)
29

H
HuangXW 已提交
30 31 32
- **位于后台的应用,启动组件需校验BACKGROUND权限**
  - 应用前后台判断标准:若应用进程获焦或所属的UIAbility位于前台则判定为前台应用,否则为后台应用
  - 需校验`ohos.permission.START_ABILITIES_FROM_BACKGROUND`权限
33

H
HuangXW 已提交
34 35 36 37 38
- **跨应用启动FA模型的ServiceAbility组件或DataAbility组件,对端应用需配置关联启动**
  - 只针对跨应用场景
  - 只针对目标组件为ServiceAbility与DataAbility生效
  - 目标应用的AssociateWakeUp为**ture**,其提供的ServiceAbility与DataAbility才允许被其他应用访问
  - 只有系统预置应用才允许配置AssociateWakeUp字段,其余应用AssociateWakeUp默认为**false**
39 40


zyjhandsome's avatar
zyjhandsome 已提交
41
> **说明:**
42 43 44 45
> 1. 组件启动管控自OpenHarmony v3.2 Release版本开始落地。
> 
> 2. 与原本的启动规则不同,新的组件启动规则较为严格,开发者需熟知启动规则,避免业务功能异常。

H
HuangXW 已提交
46 47 48 49
启动组件的具体校验流程见下文。


## 同设备组件启动规则
50

H
HuangXW 已提交
51
  设备内启动组件,不同场景下的规则不同,可分为如下两种场景:
52

H
HuangXW 已提交
53
- 启动PageAbility。
54

H
HuangXW 已提交
55
- 启动ServiceAbility或DataAbility。
56

H
HuangXW 已提交
57
![startup-rule](figures/component-startup-inner-fa.png)
58 59


H
HuangXW 已提交
60
## 分布式跨设备组件启动规则
61

H
HuangXW 已提交
62
  跨设备启动组件,不同场景下的规则不同,可分为如下两种场景:
63 64 65

- 启动PageAbility。

H
HuangXW 已提交
66
- 启动ServiceAbility。
67

H
HuangXW 已提交
68
![component-startup-rules](figures/component-startup-inter-fa.png)