js-apis-hiappevent.md 8.3 KB
Newer Older
1
# @ohos.hiAppEvent (应用打点)
Z
zengyawen 已提交
2

L
lyj_love_code 已提交
3 4
本模块提供了应用事件打点能力,包括对打点数据的落盘,以及对打点功能的管理配置。

zyjhandsome's avatar
zyjhandsome 已提交
5 6
> **说明:**
>
Z
zengyawen 已提交
7
> - 本模块接口从API version 9开始废弃,建议使用新接口[`@ohos.hiviewdfx.hiAppEvent`](js-apis-hiviewdfx-hiappevent.md)替代。
L
lyj_love_code 已提交
8
> - 本模块首批接口从API version 7开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。
Z
zengyawen 已提交
9

Z
zengyawen 已提交
10 11

## 导入模块
Z
zengyawen 已提交
12

L
lyj_love_code 已提交
13
```ts
Z
zengyawen 已提交
14 15 16
import hiAppEvent from '@ohos.hiAppEvent';
```

L
lyj_love_code 已提交
17
## 使用说明
Z
zengyawen 已提交
18

L
lyj_love_code 已提交
19 20 21 22
开发者在使用应用事件打点功能前,需要首先了解应用事件相关的参数规格定义。

**事件名称**

23
事件名称为string类型,字符串非空且长度在48个字符以内,有效的字符是数字字符、字母字符、下划线字符,只能以字母字符或$字符开头,不能以下划线字符结尾。
L
lyj_love_code 已提交
24 25 26 27 28 29 30 31 32

**事件类型**

事件类型为[EventType](#eventtype)枚举类型。

**事件参数**

事件参数为object类型,key为事件的参数名称,value为事件的参数值,其规格定义如下:

33
- 参数名为string类型,字符串非空且长度在16个字符以内,有效的字符是数字字符、字母字符、下划线字符,只能以字母字符或$字符开头,不能以下划线字符结尾;
34 35 36 37
- 参数值支持string、number、boolean、数组类型;
- 参数值为string类型时,其长度需在8*1024个字符以内,超出会做丢弃处理;
- 参数值为number类型时,其取值需在Number.MIN_SAFE_INTEGER~Number.MAX_SAFE_INTEGER范围内,超出可能会产生不确定值;
- 参数值为数组类型时,数组中的元素类型只能全为string、number、boolean中的一种,且元素个数需在100以内,超出会做丢弃处理;
L
lyj_love_code 已提交
38 39 40 41 42 43 44 45 46 47
- 参数个数需在32以内,超出的参数会做丢弃处理。

**事件回调**

开发者在调用事件打点方法后,可以在回调函数中对打点返回值进行处理,当前支持callback形式和Promise形式的回调,其返回值规格定义如下:

- 返回值为0,表示事件校验成功,将事件直接落盘到事件文件;
- 返回值大于0,表示事件校验存在异常参数,在忽略异常参数后将事件落盘到事件文件;
- 返回值小于0,表示事件校验失败,不将事件落盘到事件文件。

L
lyj_love_code 已提交
48
## hiAppEvent.write
Z
zengyawen 已提交
49 50

write(eventName: string, eventType: EventType, keyValues: object, callback: AsyncCallback<void>): void
Z
zengyawen 已提交
51

L
lyj_love_code 已提交
52
应用事件打点方法,将事件写入到当天的事件文件中,使用callback方式作为异步回调。
Z
zengyawen 已提交
53

Z
zengyawen 已提交
54 55
**系统能力:** SystemCapability.HiviewDFX.HiAppEvent

Z
zengyawen 已提交
56 57
**参数:**

L
lyj_love_code 已提交
58 59 60 61 62
| 参数名    | 类型                      | 必填 | 说明           |
| --------- | ------------------------- | ---- | -------------- |
| eventName | string                    | 是   | 事件名称。     |
| eventType | [EventType](#eventtype)   | 是   | 事件类型。     |
| keyValues | object                    | 是   | 事件参数。     |
63
| callback  | AsyncCallback<void> | 是   | 事件回调函数。 |
Z
zengyawen 已提交
64 65 66

**示例:**

L
lyj_love_code 已提交
67 68 69 70 71 72 73 74 75 76 77 78 79 80 81
```ts
import { BusinessError } from 'ohos.base'

let eventParams: Record<string, number | string> = {
  "int_data": 100,
  "str_data": "strValue",
};
hiAppEvent.write("test_event", hiAppEvent.EventType.FAULT, eventParams, (err: BusinessError) => {
  if (err) {
    // 事件写入异常:事件存在异常参数时忽略异常参数后继续写入,或者事件校验失败时不执行写入
    console.error(`failed to write event, code=${err.code}`);
    return;
  }
  // 事件写入正常
  console.log(`success to write event`);
Z
zengyawen 已提交
82 83
});
```
Z
zengyawen 已提交
84 85


L
lyj_love_code 已提交
86
## hiAppEvent.write
Z
zengyawen 已提交
87 88

write(eventName: string, eventType: EventType, keyValues: object): Promise&lt;void&gt;
Z
zengyawen 已提交
89

L
lyj_love_code 已提交
90
应用事件打点方法,将事件写入到当天的事件文件中,使用Promise方式作为异步回调。
Z
zengyawen 已提交
91

Z
zengyawen 已提交
92 93
**系统能力:** SystemCapability.HiviewDFX.HiAppEvent

Z
zengyawen 已提交
94 95
**参数:**

L
lyj_love_code 已提交
96 97 98 99 100
| 参数名    | 类型                    | 必填 | 说明       |
| --------- | ----------------------- | ---- | ---------- |
| eventName | string                  | 是   | 事件名称。 |
| eventType | [EventType](#eventtype) | 是   | 事件类型。 |
| keyValues | object                  | 是   | 事件参数。 |
Z
zengyawen 已提交
101 102 103

**返回值:**

104 105
| 类型                | 说明                                                         |
| ------------------- | ------------------------------------------------------------ |
L
lyj_love_code 已提交
106
| Promise&lt;void&gt; | Promise对象,可以在其then()、catch()方法中分别对事件写入成功、写入异常的情况进行异步处理。 |
Z
zengyawen 已提交
107 108 109

**示例:**

L
lyj_love_code 已提交
110 111 112 113 114 115 116 117 118 119 120 121 122 123
```ts
import { BusinessError } from 'ohos.base'

let eventParams: Record<string, number | string> = {
  "int_data": 100,
  "str_data": "strValue",
};
hiAppEvent.write("test_event", hiAppEvent.EventType.FAULT, eventParams).then(() => {
  // 事件写入正常
  console.log(`success to write event`);
}).catch((err: BusinessError) => {
  // 事件写入异常:事件存在异常参数时忽略异常参数后继续写入,或者事件校验失败时不执行写入
  console.error(`failed to write event, code=${err.code}`);
});
Z
zengyawen 已提交
124
```
Z
zengyawen 已提交
125 126 127 128

## hiAppEvent.configure

configure(config: ConfigOption): boolean
Z
zengyawen 已提交
129 130 131

应用事件打点配置方法,可用于配置打点开关、文件目录存储限额大小等功能。

Z
zengyawen 已提交
132 133
**系统能力:** SystemCapability.HiviewDFX.HiAppEvent

Z
zengyawen 已提交
134 135
**参数:**

136 137 138
| 参数名 | 类型                          | 必填 | 说明                     |
| ------ | ----------------------------- | ---- | ------------------------ |
| config | [ConfigOption](#configoption) | 是   | 应用事件打点配置项对象。 |
Z
zengyawen 已提交
139 140 141

**返回值:**

142 143
| 类型    | 说明                                                        |
| ------- | ----------------------------------------------------------- |
Z
zengyawen 已提交
144 145 146
| boolean | 配置结果,true&nbsp;表示配置成功,false&nbsp;表示配置失败。 |

**示例:**
L
lyj_love_code 已提交
147

L
lyj_love_code 已提交
148
```ts
Z
zengyawen 已提交
149
// 配置应用事件打点功能开关
L
lyj_love_code 已提交
150 151 152 153
let config1: hiAppEvent.ConfigOption = {
  disable: true,
};
hiAppEvent.configure(config1);
Z
zengyawen 已提交
154 155

// 配置事件文件目录存储限额大小
L
lyj_love_code 已提交
156 157 158 159
let config2: hiAppEvent.ConfigOption = {
  maxStorage: '100M',
};
hiAppEvent.configure(config2);
Z
zengyawen 已提交
160
```
Z
zengyawen 已提交
161 162

## ConfigOption
Z
zengyawen 已提交
163 164 165

此接口提供了应用打点的配置选项。

L
lyj_love_code 已提交
166
**系统能力:** SystemCapability.HiviewDFX.HiAppEvent
Z
zengyawen 已提交
167

168
| 名称       | 类型    | 必填 | 说明                                                         |
169 170 171
| ---------- | ------- | ---- | ------------------------------------------------------------ |
| disable    | boolean | 否   | 应用打点功能开关。配置值为true表示关闭打点功能,false表示不关闭打点功能。 |
| maxStorage | string  | 否   | 打点数据本地存储文件所在目录的配额大小,默认限额为“10M”。所在目录大小超出限额后会对目录进行清理操作,会按从旧到新的顺序逐个删除打点数据文件,直到目录大小不超出限额时停止。 |
Z
zengyawen 已提交
172 173 174


## EventType
Z
zengyawen 已提交
175 176 177

事件类型枚举。

L
lyj_love_code 已提交
178
**系统能力:** SystemCapability.HiviewDFX.HiAppEvent
Z
zengyawen 已提交
179

180 181 182 183 184 185
| 名称      | 值   | 说明           |
| --------- | ---- | -------------- |
| FAULT     | 1    | 故障类型事件。 |
| STATISTIC | 2    | 统计类型事件。 |
| SECURITY  | 3    | 安全类型事件。 |
| BEHAVIOR  | 4    | 行为类型事件。 |
Z
zengyawen 已提交
186 187 188


## Event
Z
zengyawen 已提交
189 190 191

此接口提供了所有预定义事件的事件名称常量。

L
lyj_love_code 已提交
192
**系统能力:** SystemCapability.HiviewDFX.HiAppEvent
Z
zengyawen 已提交
193

194 195 196 197 198
| 名称                      | 类型   | 可读 | 可写 | 说明                 |
| ------------------------- | ------ | ---- | ---- | -------------------- |
| USER_LOGIN                | string | 是   | 否   | 用户登录事件。       |
| USER_LOGOUT               | string | 是   | 否   | 用户登出事件。       |
| DISTRIBUTED_SERVICE_START | string | 是   | 否   | 分布式服务启动事件。 |
Z
zengyawen 已提交
199 200


Z
zengyawen 已提交
201 202 203
## Param

此接口提供了所有预定义参数的参数名称常量。
Z
zengyawen 已提交
204

L
lyj_love_code 已提交
205
**系统能力:** SystemCapability.HiviewDFX.HiAppEvent
Z
zengyawen 已提交
206

207 208 209 210 211
| 名称                            | 类型   | 可读 | 可写 | 说明               |
| ------------------------------- | ------ | ---- | ---- | ------------------ |
| USER_ID                         | string | 是   | 否   | 用户自定义ID。     |
| DISTRIBUTED_SERVICE_NAME        | string | 是   | 否   | 分布式服务名称。   |
| DISTRIBUTED_SERVICE_INSTANCE_ID | string | 是   | 否   | 分布式服务实例ID。 |