鸿蒙Next开发 获取APP缓存大小和清除缓存

1. 鸿蒙Next开发 获取APP缓存大小和清除缓存

1.1. 介绍

1.1.1. 文件系统分类

  在最新的Core File Kit套件中,按文件所有者的不同。分为如下三类:

  (1)应用文件:文件所有者为应用,包括应用安装文件、应用资源文件、应用缓存文件等。

  (2)用户文件:文件所有者为登录到该终端设备的用户,包括用户私有的图片、视频、音频、文档等。

  (3)系统文件:与应用和用户无关的其它文件,包括公共库、设备文件、系统资源文件等。这类文件普通开发者不需要关注。

1.1.2. 访问范围和方式

  我们的应用缓存目录,实质是系统在内部存储空间上映射出一个专属应用沙箱目录其中的一部分,它是应用文件目录与一部分系统文件(应用运行必需的少量系统文件)所在的目录组成的集合。

  (1)应用可以在应用沙箱目录下保存和处理自己的应用文件;

  (2)系统文件及其目录对于应用是只读的;

  (3)应用若需访问用户文件,则需要通过特定API同时经过用户的相应授权才能进行(即读写权限申请)。

  下图展示了在鸿蒙上,应用可访问的文件范围和方式:

1.1.2. 应用文件目录与路径

如上图所示,这是应用文件的目录结构图。

  一级目录data/:代表应用文件目录。

  二级目录storage/:代表本应用持久化文件目录。

  三级目录el1/、el2/:代表不同文件加密类型。

    el1,设备级加密区:设备开机后即可访问的数据区。

    el2,用户级加密区:设备开机后,需要至少一次解锁对应用户的锁屏界面(密码、指纹、人脸等方式或无密码状态)后,才能够访问的加密数据区。(应用如无特殊需要,应将数据存放在el2加密目录下,以尽可能保证数据安全。)

  四级、五级目录:

  ApplicationContext:可以获取distributedfiles目录或者base下的files、cache、preferences、temp等目录的应用文件路径,应用全局信息可以存放在这些目录下。

  UIAbilityContext、AbilityStageContext、ExtensionContext:HAP级别应用文件路径(上图中的haps//下的目录)。HAP信息可以存放在这些目录下,存放在此目录的文件会跟随HAP的卸载而删除,不会影响App级别目录下的文件。

1.2. 获取APP缓存大小

1.2.1. 缓存目录介绍

  目录名:cache

  Context属性名称:cacheDir

  类型:应用缓存文件路径

  说明:应用在本设备内部存储上,用于缓存下载的文件或可重新生成的缓存文件的路径,应用cache目录大小超过配额或者系统空间达到一定条件,自动触发清理该目录下文件;用户通过系统空间管理类应用也可能触发清理该目录。应用需判断文件是否仍存在,决策是否需重新缓存该文件。 可以用于保存应用的缓存数据,主要包括离线数据、图片缓存、数据库备份以及临时文件等。此路径下存储的数据可能会被系统自动清理,因此不要存储重要数据。

1.2.2. 缓存目录路径

复制代码
/data/storage/el1/base/cache
/data/storage/el1/base/haps/entry/cache
/data/storage/el2/base/cache
/data/storage/el2/base/haps/entry/cache

1.2.3. 获取缓存目录

  el1分区获取:

  (1)切换到el1加密分区

javascript 复制代码
context.getApplicationContext().area = contextConstant.AreaMode.EL1;
context.area = contextConstant.AreaMode.EL1;
context.getApplicationContext().cacheDir
context.cacheDir
//结果:
/data/storage/el1/base/cache
/data/storage/el1/base/haps/app/cache

  (2)切换到el2加密分区

javascript 复制代码
context.getApplicationContext().area = contextConstant.AreaMode.EL2;
context.area = contextConstant.AreaMode.EL2;
context.getApplicationContext().cacheDir
context.cacheDir
//结果:
/data/storage/el2/base/cache
/data/storage/el2/base/haps/app/cache

1.2.4. 获取缓存大小

javascript 复制代码
import storageStatistics from "@ohos.file.storageStatistics";
const bundleStats = await storageStatistics.getCurrentBundleStats()
return bundleStats.cacheSize

1.2.5. 清除缓存

javascript 复制代码
static async cleanAppCache(context: Context): Promise<boolean> {
  context.getApplicationContext().area = contextConstant.AreaMode.EL1;
  context.area = contextConstant.AreaMode.EL1;
  const el1AppCacheDir = context.getApplicationContext().cacheDir
  const el1HapCacheDir = context.cacheDir
  context.getApplicationContext().area = contextConstant.AreaMode.EL2;
  context.area = contextConstant.AreaMode.EL2;
  const el2AppCacheDir = context.getApplicationContext().cacheDir
  const el2HapCacheDir = context.cacheDir

  const task = [
    AppInfoUtils.clearCacheTask(el1AppCacheDir),
    AppInfoUtils.clearCacheTask(el1HapCacheDir),
    AppInfoUtils.clearCacheTask(el2AppCacheDir),
    AppInfoUtils.clearCacheTask(el2HapCacheDir)
  ]

  await Promise.all(task)
  return true
}

private static clearCacheTask(dir: string): Promise<boolean> {
  return new Promise((resolve) => {
    fileIo.access(dir).then((exist: boolean) => {
      if (exist) {
        fileIo.rmdir(dir)
      }
      resolve(true)
    })
  })
}

1.3. 示例

1.3.1. 获取缓存大小

  storageStatistics.getCurrentBundleStats 第三方应用异步获取当前应用存储空间大小(单位为Byte),以Promise方式返回。

javascript 复制代码
  @State
  cache: string = ''
  calcCache() {
//获取当前应用的资源信息
    storageStatistics.getCurrentBundleStats()
      .then(res => {
        this.cache = (res.cacheSize / (1000 * 1000)).toFixed(2) + 'MB'
      })
  }
  onPageShow(): void {
    this.calcCache()
  }

1.3.2. 清理缓存

  (1)accessSync(path: string, mode?: AccessModeType): boolean 以同步方法检查文件是否存在。

  (2)rmdirSync(path: string): void 以同步方法删除目录。

  (3)应用有两个缓存目录,一个 entry hap的,一个应用的

  实现步骤:获取上下文--》获取cache目录--》判断是否有该目录--》删除该目录。

javascript 复制代码
clearCache() {
    const ctx = getContext()
//获取当前ability的缓存路径
    const ctxCacheDir = ctx.cacheDir
//判断是否有这个文件
    const ctxExist = fileIo.accessSync(ctxCacheDir)
    if (ctxExist) {
//清除缓存
      fileIo.rmdirSync(ctxCacheDir)
    }
//获得应用级的上下文
    const app = ctx.getApplicationContext()
//应用级的缓存目录
    const appCacheDir = app.cacheDir
//判断有无文件
    const appExist = fileIo.accessSync(appCacheDir)
    if (appExist) {
//清除缓存
      fileIo.rmdirSync(appCacheDir)
    }
    promptAction.showToast({ message: '清理完毕' })
    this.calcCache()
  }
相关推荐
鸿蒙开发1 小时前
鸿蒙(HarmonyOS NEXT)表单校验别再手撸正则了 —— 我写了个 ArkTS 版 zod
harmonyos
TrisighT2 小时前
ArkTS 的 @BuilderParam 你八成只用了皮毛——那个尾随闭包写法差点被我当 bug 删了
harmonyos·arkts·arkui
ONEDAY1 天前
HarmonyOS 多 Product 构建实践:一套代码生成多个产物
harmonyos
TT_Close1 天前
别劝退了!5秒搞定 Flutter 鸿蒙 FVM 起跑线
flutter·harmonyos·visual studio code
TrisighT1 天前
ArkTS 列表滚动时为什么会闪现旧数据?我扒了 LazyForEach 的复用逻辑
harmonyos·arkts·arkui
MonkeyKing1 天前
鸿蒙ArkTS深度剖析:ArkTS与TS/JS核心差异、静态强类型实战优势
typescript·harmonyos
TrisighT1 天前
Electron鸿蒙PC上写日志文件,我被权限和路径坑了两次
electron·harmonyos
TrisighT2 天前
一个下午搞定 ArkTS 折叠面板?结果我从两点写到晚上九点
harmonyos·arkts·arkui
花椒技术5 天前
HJPusher / HJPlayer SDK 实践:我们为什么把直播推播链路拆成一套可复用能力
设计模式·harmonyos·直播
一维Ace5 天前
HarmonyOS ArkTS 按钮组件全解:Button、Toggle 状态交互实战
harmonyos