1# HiAppEvent常见问题 2 3<!--Kit: Performance Analysis Kit--> 4<!--Subsystem: HiviewDFX--> 5<!--Owner: @liujiaxing2024--> 6<!--Designer: @junjie_shi--> 7<!--Tester: @gcw_KuLfPSbe--> 8<!--Adviser: @foryourself--> 9 10## 查不到已通过HiAppEvent订阅的事件内容 11 12**问题现象** 13 14在开发调试阶段,崩溃、应用冻屏等故障发生后,无法在DevEco Studio的HiLog窗口中获取已通过HiAppEvent订阅的事件内容。 15 16**可能的原因&解决措施** 17 18发生崩溃、应用冻屏等故障后,应用已退出。 19 20解决办法:再次启动应用,查看相应的事件内容。 21 22 23## 无法获取external_log日志文件 24 25**问题现象** 26 27Hilog中出现如下日志: 28 29- eventInfo.params.external_log=[] 30 31- HiAppEvent file does not exist 32 33**可能的原因&解决措施** 34 35**情况一**: 36 37external_log日志文件所在目录的空间已达到上限。 38 39external_log所在的目录为[应用沙箱目录](../file-management/app-sandbox-directory.md),目录空间受限。log_over_limit字段用于判断external_log日志文件所在目录的空间是否达到上限。如果log_over_limit的值为true,表示external_log日志文件所在目录空间已达到上限,事件包含的日志文件将无法写入。 40 41external_log是一个字符串数组。例如: 42 43external_log=["/data/storage/el2/log/hiappevent/APP_CRASH_时间戳_xxxx.log"]。 44 45**可采取的解决措施**: 46 47参考[无法删除external_log日志文件](#无法删除external_log日志文件)中的解决措施,清理历史日志文件。 48 49**情况二**: 50 51部分系统事件(如启动耗时事件)本身没有external_log,因而没有external_log日志文件。 52 53**可采取的解决措施**: 54 55查看对应的事件介绍章节,确认事件是否包含external_log:[系统事件](event-subscription-overview.md#系统事件)。 56 57**情况三**: 58 59事件发生在事件订阅之前。 60 61在调用事件订阅接口addWatcher()前,没有开始监听系统事件。因此事件订阅之前的事件没有external_log日志文件。 62 63**可采取的解决措施**: 64 65确认事件订阅与事件发生的时序关系。先事件订阅,然后事件发生,才能获取到事件的external_log日志文件。 66 67**情况四**: 68 69系统事件没有触发成功。 70 71如果系统事件没发生,就不会有external_log日志文件。 72 73**可采取的解决措施**: 74 75查看系统事件的其他日志,确认系统事件是否已经触发成功。 76 77**情况五**: 78 79external_log日志文件生成后又被删除了。 80 81例如,在一个应用中,A和B两个模块都订阅了系统事件C。A模块处理完系统事件C的回调后,删除了external_log日志文件。随后B模块在系统事件C的回调中访问external_log日志文件,会提示日志文件不存在。 82 83**可采取的解决措施**: 84 85检查其他模块是否已删除external_log日志文件。 86 87 88## 无法删除external_log日志文件 89 90**问题现象** 91 92external_log日志文件所在目录的空间已达到上限,但无法删除external_log日志文件。 93 94**解决措施** 95 96- 开发者如果有权限访问设备的/data/app目录,可以手动删除external_log日志文件。文件目录为 97 /data/app/el2/100/log/应用包名/hiappevent(或resourcelimit或watchdog)。 98 99- 开发者若没有权限访问设备的/data/app目录,可以在应用代码中删除external_log日志文件。代码示例如下。文件删除接口可以参考[fs.unlink](../reference/apis-core-file-kit/js-apis-file-fs.md#fsunlink)。 100 101**代码示例** 102 103```ts 104import { fileIo as fs } from '@kit.CoreFileKit'; 105import { BusinessError } from '@kit.BasicServicesKit'; 106 107if (eventInfo.params['external_log'] != undefined) { 108 for (let index = 0; index < eventInfo.params['external_log'].length; ++index) { 109 let externalLog: string = eventInfo.params['external_log'][index]; 110 hilog.info(0x0000, 'testTag', `externalLog=${externalLog}`); 111 // 验证访问权限: 112 let res = fs.accessSync(externalLog); 113 if (res) { 114 hilog.info(0x0000, 'testTag', `HiAppEvent file exists`); 115 } else { 116 hilog.error(0x0000, 'testTag', `HiAppEvent file does not exist`); 117 } 118 // 验证读写权限: 119 fs.open(externalLog, fs.OpenMode.READ_WRITE).then((file: fs.File) => { 120 hilog.info(0x0000, 'testTag', `HiAppEvent file=${externalLog} fd=${file.fd}`); 121 fs.closeSync(file); 122 }).catch((err: BusinessError) => { 123 hilog.info(0x0000, 'testTag', 124 `HiAppEvent open file=${externalLog} failed with error message=${err.message}, error code=${err.code}`); 125 }); 126 // 删除external_log日志文件: 127 fs.unlink(externalLog).then(() => { 128 console.info("HiAppEvent remove file:" + externalLog + " succeed"); 129 }).catch((err: BusinessError) => { 130 console.error("HiAppEvent remove file:" + externalLog + " failed with error message: " + err.message + 131 ", error code: " + err.code); 132 }); 133 } 134} 135``` 136 137访问及删除external_log日志文件的日志: 138 139```text 140externalLog=/data/storage/el2/log/hiappevent/APP_CRASH_1751081104816_35595.log 141HiAppEvent file exists 142HiAppEvent file=/data/storage/el2/log/hiappevent/APP_CRASH_1751081104816_35595.log fd=61 143HiAppEvent remove file:/data/storage/el2/log/hiappevent/APP_CRASH_1751081104816_35595.log succeed 144``` 145 146 147> **说明:** 148> 149> external_log返回的路径是应用沙箱目录,非真实物理路径。应用有权限访问自己的沙箱目录。external_log日志空间受限,应用处理完日志文件后应及时删除。 150 151 152## 同一应用内,事件的回调不区分线程、进程 153 154例如,在同一个应用内,有A、B两个进程,进程A已调用addWatcher()接口订阅崩溃事件。如果进程B发生崩溃,进程A能收到进程B的崩溃回调。只要进程A和B的应用名一致即可。 155 156**接口参考链接** 157 158[hiAppEvent.addWatcher](../reference/apis-performance-analysis-kit/js-apis-hiviewdfx-hiappevent.md#hiappeventaddwatcher)。 159