• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1# 组件启动规则(Stage模型)
2
3<!--Kit: Ability Kit-->
4<!--Subsystem: Ability-->
5<!--Owner: @littlejerry1-->
6<!--Designer: @ccllee1-->
7<!--Tester: @lixueqing513-->
8<!--Adviser: @huipeizi-->
9
10启动组件是指一切启动或连接应用组件的行为:
11
12
13- 启动[UIAbility](../reference/apis-ability-kit/js-apis-app-ability-uiAbility.md)、ServiceExtensionAbility、DataShareExtensionAbility,如使用[startAbility()](../reference/apis-ability-kit/js-apis-inner-application-uiAbilityContext.md#startability)、startServiceExtensionAbility()、[startAbilityByCall()](../reference/apis-ability-kit/js-apis-inner-application-uiAbilityContext.md#startabilitybycall)、[openLink()](../reference/apis-ability-kit/js-apis-inner-application-uiAbilityContext.md#openlink12)等相关接口。
14
15- 连接ServiceExtensionAbility、DataShareExtensionAbility,如使用[connectServiceExtensionAbility()](../reference/apis-ability-kit/js-apis-inner-application-uiAbilityContext.md#connectserviceextensionability)、createDataShareHelper()等相关接口。
16
17## 组件启动总体规则
18
19为了保证用户具有更好的使用体验,对以下几种易影响用户体验与系统安全的行为做了限制:
20
21
22- 后台应用任意弹框,如各种广告弹窗,影响用户使用。
23
24- 后台应用相互唤醒,不合理的占用系统资源,导致系统功耗增加或系统卡顿。
25
26- 前台应用任意跳转至其他应用,如随意跳转到其他应用的支付页面,存在安全风险。
27
28
29鉴于此,制订了一套组件启动规则,主要包括:
30
31- **跨应用启动组件,需校验目标组件是否可以被其他应用调用。**
32
33  若目标组件exported字段配置为true,表示可以被其他应用调用;若目标组件exported字段配置为false,表示不可以被其他应用调用,还需进一步校验`ohos.permission.START_INVISIBLE_ABILITY`权限(该权限仅系统应用可申请)。组件exported字段说明可参考[abilities标签](../quick-start/module-configuration-file.md#abilities标签)。
34
35- **位于后台的UIAbility应用,启动组件需校验BACKGROUND权限`ohos.permission.START_ABILITIES_FROM_BACKGROUND`(该权限仅系统应用可申请)。对于2in1和Tablet设备,如果应用已创建在前台显示的悬浮窗,当该应用退至后台时,无需校验BACKGROUND权限也可以拉起其他Ability。**
36
37  > 说明:
38  >
39  > 前后台应用的判断依据:若应用进程获焦或所属的UIAbility组件位于前台则判定为前台应用,否则为后台应用。
40
41- **跨设备使用startAbilityByCall接口,需校验分布式权限`ohos.permission.DISTRIBUTED_DATASYNC`。**
42
43上述组件启动规则自API 9版本开始生效。开发者需熟知组件启动规则,避免业务功能异常。启动组件的具体校验流程见下文。
44
45
46
47## 同设备组件启动规则
48
49  设备内启动组件,不同场景下的规则不同,可分为如下三种场景:
50
51- 启动UIAbility。
52
53- 启动ServiceExtensionAbility、DataShareExtensionAbility。
54
55- 通过[startAbilityByCall](../reference/apis-ability-kit/js-apis-inner-application-uiAbilityContext.md#startabilitybycall)接口启动UIAbility。
56
57![startup-rule](figures/component-startup-inner-stage.png)
58
59
60## 分布式跨设备组件启动规则
61
62  跨设备启动组件,不同场景下的规则不同,可分为如下三种场景:
63
64- 启动UIAbility。
65
66- 启动ServiceExtensionAbility、DataShareExtensionAbility。
67
68- 通过[startAbilityByCall](../reference/apis-ability-kit/js-apis-inner-application-uiAbilityContext.md#startabilitybycall)接口启动UIAbility。
69
70![component-startup-rules](figures/component-startup-inter-stage.png)
71