• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1# Component Startup Rules (FA Model)
2
3
4Component startup refers to the behavior of starting or connecting to an application component.
5
6
7- Start the PageAbility and ServiceAbility. For example, you can use **startAbility()**.
8
9- Connect to the ServiceAbility and DataAbility. For example, you can use **connectAbility()** and **acquireDataAbilityHelper()**.
10
11
12To deliver a better user experience, OpenHarmony restricts the following behavior:
13
14
15- A background application randomly displays a dialog box, such as an ads pop-up.
16
17- Background applications wake up each other. This type of behavior occupies system resources and increases power consumption, or even causes system frozen.
18
19- A foreground application randomly redirects to another application, for example, redirecting to the payment page of another application. This type of behavior poses security risks.
20
21
22In view of this, OpenHarmony formulates a set of component startup rules, as follows:
23
24
25- **Before starting a component of another application, verify the visible field of the target component.**
26  - This rule applies only to cross-application scenarios.
27  - If the **visible** field of the target component is **false**, verify the **ohos.permission.START_INVISIBLE_ABILITY** permission.
28  - For details, see [Component Visible Configuration](../quick-start/module-configuration-file.md#abilities).
29
30- **Before starting a component of a background application, verify the BACKGROUND permission.**
31  - An application is considered as a foreground application only when the application process gains focus or its UIAbility component is running in the foreground.
32  - Verify the **ohos.permission.START_ABILITIES_FROM_BACKGROUND** permission.
33
34- **Before starting the ServiceAbility or DataAbility component of an application, verify the AssociateWakeUp field of the target application.**
35  - This rule applies only to cross-application scenarios.
36  - This rule is valid only when the target component is ServiceAbility or DataAbility.
37  - The ServiceAbility and DataAbility of an application can be accessed by others only when **AssociateWakeUp** of the target application is set to **true**.
38  - The **AssociateWakeUp** field can be configured only for preset applications. For other applications, this field is set to **false** by default.
39
40
41> **NOTE**
42> 1. Component startup control has been implemented since OpenHarmony v3.2 Release.
43>
44> 2. The new component startup rules are more strict than the original ones. You must be familiar with the new startup rules to prevent service exceptions.
45
46
47
48
49## Intra-Device Component Startup Rules
50
51  The rules for starting components on the same device vary in the following scenarios:
52
53- Starting a PageAbility
54
55- Starting a ServiceAbility or DataAbility
56
57![startup-rule](figures/component-startup-inner-fa.png)
58
59
60## Inter-Device Component Startup Rules
61
62  The rules for starting components on a different device vary in the following scenarios:
63
64- Starting a PageAbility
65
66- Starting a ServiceAbility
67
68![component-startup-rules](figures/component-startup-inter-fa.png)
69
70