鸿蒙开发系统基础能力:【@ohos.hiAppEvent (应用打点)】

2024-06-24 00:20

本文主要是介绍鸿蒙开发系统基础能力:【@ohos.hiAppEvent (应用打点)】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

应用打点

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

icon-note.gif 说明:  本模块首批接口从API version 7开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。

导入模块

import hiAppEvent from '@ohos.hiAppEvent';

hiAppEvent.write

write(eventName: string, eventType: EventType, keyValues: object, callback: AsyncCallback): void

应用事件打点方法,将事件写入到当天的事件文件中,可接收类型为Json对象的事件参数,使用callback方式作为异步回调。

系统能力:  SystemCapability.HiviewDFX.HiAppEvent

参数:

参数名类型必填说明
eventNamestring应用事件名称。 由开发者自定义。事件名称在48个字符以内,有效的字符是0-9、a-z、下划线,只能以字母开头。
eventType[EventType]应用事件类型。
keyValuesobject事件参数键值对,如果是变长参数类型,则依次输入事件的参数名与参数值。如果是Json对象类型,则Json对象的key是事件的参数名,value是事件的参数值。 - key类型只能为string,value类型只能为string、number、boolean、Array(数组数据类型只能为string、number、boolean)。 - 事件的参数个数必须小于等于32。 - 参数名在16个字符以内,有效的字符是0-9、a-z、下划线,只能以字母开头,不能以下划线结尾。 - string类型参数值在8*1024个字符内。 - Array类型参数值的元素个数必须在100个以内,超出时会进行截断处理。
callbackAsyncCallback回调函数,可以在回调函数中处理接口返回值。 - 返回值为0表示事件校验成功,事件正常异步写入事件文件; - 大于0表示事件校验存在异常参数,在忽略异常参数后将事件异步写入事件文件; - 小于0表示事件校验失败,不将事件写入事件文件。

示例:

hiAppEvent.write("test_event", hiAppEvent.EventType.FAULT, {"int_data":100, "str_data":"strValue"}, (err, value) => {if (err) {// 事件写入异常:事件存在异常参数时忽略异常参数后继续写入,或者事件校验失败时不执行写入console.error(`failed to write event because ${err.code}`);return;}// 事件写入正常console.log(`success to write event: ${value}`);
});

hiAppEvent.write

write(eventName: string, eventType: EventType, keyValues: object): Promise

应用事件打点方法,将事件写入到当天的事件文件中,可接收类型为Json对象的事件参数,使用promise方式作为异步回调。

系统能力:  SystemCapability.HiviewDFX.HiAppEvent

参数:

参数名类型必填说明
eventNamestring应用事件名称。 由开发者自定义。事件名称在48个字符以内,有效的字符是0-9、a-z、下划线,只能以字母开头。
eventType[EventType]应用事件类型。
keyValuesobject事件参数键值对,如果是变长参数类型,则依次输入事件的参数名与参数值。如果是Json对象类型,则Json对象的key是事件的参数名,value是事件的参数值。 - key类型只能为string,value类型只能为string、number、boolean、Array(数组数据类型只能为string、number、boolean)。 - 事件的参数个数必须小于等于32。 - 参数名在16个字符以内,有效的字符是0-9、a-z、下划线,只能以字母开头,不能以下划线结尾。 - string类型参数值在8*1024个字符内。 - Array类型参数值的元素个数必须在100个以内,超出时会进行截断处理。

返回值:

类型说明
PromisePromise实例,可以在其then()、catch()方法中分别对事件写入成功、写入异常的情况进行回调处理。

示例:

hiAppEvent.write("test_event", hiAppEvent.EventType.FAULT, {"int_data":100, "str_data":"strValue"}).then((value) => {// 事件写入正常console.log(`success to write event: ${value}`);}).catch((err) => {// 事件写入异常:事件存在异常参数时忽略异常参数后继续写入,或者事件校验失败时不执行写入console.error(`failed to write event because ${err.code}`);});

hiAppEvent.configure

configure(config: ConfigOption): boolean

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

系统能力:  SystemCapability.HiviewDFX.HiAppEvent

参数:

参数名类型必填说明
config[ConfigOption]应用事件打点配置项对象。

返回值:

类型说明
boolean配置结果,true 表示配置成功,false 表示配置失败。

示例:

// 配置应用事件打点功能开关
hiAppEvent.configure({disable: true
});// 配置事件文件目录存储限额大小
hiAppEvent.configure({maxStorage: '100M'
});

ConfigOption

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

系统能力:  以下各项对应的系统能力均为SystemCapability.HiviewDFX.HiAppEvent。

参数名类型必填说明
disableboolean应用打点功能开关。配置值为true表示关闭打点功能,false表示不关闭打点功能。
maxStoragestring打点数据本地存储文件所在目录的配额大小,默认限额为“10M”。所在目录大小超出限额后会对目录进行清理操作,会按从旧到新的顺序逐个删除打点数据文件,直到目录大小不超出限额时停止。

EventType

事件类型枚举。

系统能力:  以下各项对应的系统能力均为SystemCapability.HiviewDFX.HiAppEvent。

名称默认值说明
FAULT1故障类型事件。
STATISTIC2统计类型事件。
SECURITY3安全类型事件。
BEHAVIOR4行为类型事件。

Event

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

系统能力:  以下各项对应的系统能力均为SystemCapability.HiviewDFX.HiAppEvent。

名称参数类型可读可写说明
USER_LOGINstring用户登录事件。
USER_LOGOUTstring用户登出事件。
DISTRIBUTED_SERVICE_STARTstring分布式服务启动事件。

Param

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

系统能力:  以下各项对应的系统能力均为SystemCapability.HiviewDFX.HiAppEvent。

名称参数类型可读可写说明
USER_IDstring用户自定义ID。
DISTRIBUTED_SERVICE_NAMEstring分布式服务名称。
DISTRIBUTED_SERVICE_INSTANCE_IDstring分布式服务实例ID。

这篇关于鸿蒙开发系统基础能力:【@ohos.hiAppEvent (应用打点)】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1088693

相关文章

5分钟获取deepseek api并搭建简易问答应用

《5分钟获取deepseekapi并搭建简易问答应用》本文主要介绍了5分钟获取deepseekapi并搭建简易问答应用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需... 目录1、获取api2、获取base_url和chat_model3、配置模型参数方法一:终端中临时将加

使用DeepSeek API 结合VSCode提升开发效率

《使用DeepSeekAPI结合VSCode提升开发效率》:本文主要介绍DeepSeekAPI与VisualStudioCode(VSCode)结合使用,以提升软件开发效率,具有一定的参考价值... 目录引言准备工作安装必要的 VSCode 扩展配置 DeepSeek API1. 创建 API 请求文件2.

JavaScript中的isTrusted属性及其应用场景详解

《JavaScript中的isTrusted属性及其应用场景详解》在现代Web开发中,JavaScript是构建交互式应用的核心语言,随着前端技术的不断发展,开发者需要处理越来越多的复杂场景,例如事件... 目录引言一、问题背景二、isTrusted 属性的来源与作用1. isTrusted 的定义2. 为

C#实现系统信息监控与获取功能

《C#实现系统信息监控与获取功能》在C#开发的众多应用场景中,获取系统信息以及监控用户操作有着广泛的用途,比如在系统性能优化工具中,需要实时读取CPU、GPU资源信息,本文将详细介绍如何使用C#来实现... 目录前言一、C# 监控键盘1. 原理与实现思路2. 代码实现二、读取 CPU、GPU 资源信息1.

Python调用另一个py文件并传递参数常见的方法及其应用场景

《Python调用另一个py文件并传递参数常见的方法及其应用场景》:本文主要介绍在Python中调用另一个py文件并传递参数的几种常见方法,包括使用import语句、exec函数、subproce... 目录前言1. 使用import语句1.1 基本用法1.2 导入特定函数1.3 处理文件路径2. 使用ex

在C#中获取端口号与系统信息的高效实践

《在C#中获取端口号与系统信息的高效实践》在现代软件开发中,尤其是系统管理、运维、监控和性能优化等场景中,了解计算机硬件和网络的状态至关重要,C#作为一种广泛应用的编程语言,提供了丰富的API来帮助开... 目录引言1. 获取端口号信息1.1 获取活动的 TCP 和 UDP 连接说明:应用场景:2. 获取硬

JAVA系统中Spring Boot应用程序的配置文件application.yml使用详解

《JAVA系统中SpringBoot应用程序的配置文件application.yml使用详解》:本文主要介绍JAVA系统中SpringBoot应用程序的配置文件application.yml的... 目录文件路径文件内容解释1. Server 配置2. Spring 配置3. Logging 配置4. Ma

2.1/5.1和7.1声道系统有什么区别? 音频声道的专业知识科普

《2.1/5.1和7.1声道系统有什么区别?音频声道的专业知识科普》当设置环绕声系统时,会遇到2.1、5.1、7.1、7.1.2、9.1等数字,当一遍又一遍地看到它们时,可能想知道它们是什... 想要把智能电视自带的音响升级成专业级的家庭影院系统吗?那么你将面临一个重要的选择——使用 2.1、5.1 还是

基于Python开发电脑定时关机工具

《基于Python开发电脑定时关机工具》这篇文章主要为大家详细介绍了如何基于Python开发一个电脑定时关机工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 简介2. 运行效果3. 相关源码1. 简介这个程序就像一个“忠实的管家”,帮你按时关掉电脑,而且全程不需要你多做

高效管理你的Linux系统: Debian操作系统常用命令指南

《高效管理你的Linux系统:Debian操作系统常用命令指南》在Debian操作系统中,了解和掌握常用命令对于提高工作效率和系统管理至关重要,本文将详细介绍Debian的常用命令,帮助读者更好地使... Debian是一个流行的linux发行版,它以其稳定性、强大的软件包管理和丰富的社区资源而闻名。在使用