1e41f4b71Sopenharmony_ci# @ohos.file.BackupExtensionContext (备份恢复扩展能力) 2e41f4b71Sopenharmony_ci 3e41f4b71Sopenharmony_ciBackupExtensionContext是BackupExtension的上下文环境,继承自ExtensionContext。 4e41f4b71Sopenharmony_ci 5e41f4b71Sopenharmony_ciBackupExtensionContext模块提供访问特定BackupExtension的资源的能力,对于拓展的BackupExtension,可直接将BackupExtensionContext作为上下文环境,或者定义一个继承自BackupExtensionContext的类型作为上下文环境。 6e41f4b71Sopenharmony_ci 7e41f4b71Sopenharmony_ci> **说明:** 8e41f4b71Sopenharmony_ci> 9e41f4b71Sopenharmony_ci> - 本模块首批接口从API version 12开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。 10e41f4b71Sopenharmony_ci> - 本模块接口仅可在Stage模型下使用。 11e41f4b71Sopenharmony_ci 12e41f4b71Sopenharmony_ci## 导入模块 13e41f4b71Sopenharmony_ci 14e41f4b71Sopenharmony_ci```ts 15e41f4b71Sopenharmony_ciimport { BackupExtensionContext } from '@kit.CoreFileKit'; 16e41f4b71Sopenharmony_ci``` 17e41f4b71Sopenharmony_ci 18e41f4b71Sopenharmony_ci## 属性 19e41f4b71Sopenharmony_ci 20e41f4b71Sopenharmony_ci**系统能力**:SystemCapability.FileManagement.StorageService.Backup 21e41f4b71Sopenharmony_ci 22e41f4b71Sopenharmony_ci| 名称 | 类型 | 必填 | 说明 | 23e41f4b71Sopenharmony_ci| -------- | -------- | -------- | -------- | 24e41f4b71Sopenharmony_ci| backupDir<sup>12+</sup> | string | 是 | 获取备份恢复时的临时路径,该路径只允许在备份恢复过程中作为临时路径使用,不允许应用将该路径作为其他用途来使用。目前只支持el1, el2路径 | 25e41f4b71Sopenharmony_ci 26e41f4b71Sopenharmony_ci## 使用场景 27e41f4b71Sopenharmony_ciBackupExtensionContext主要用于获取备份恢复过程中的临时路径。 28e41f4b71Sopenharmony_ci 29e41f4b71Sopenharmony_ci**示例:** 30e41f4b71Sopenharmony_ci 31e41f4b71Sopenharmony_ci```ts 32e41f4b71Sopenharmony_ciimport { BackupExtensionAbility, BundleVersion } from '@kit.CoreFileKit'; 33e41f4b71Sopenharmony_ciimport { contextConstant } from '@kit.AbilityKit'; 34e41f4b71Sopenharmony_ci 35e41f4b71Sopenharmony_ciexport default class MyBackupExtAbility extends BackupExtensionAbility { 36e41f4b71Sopenharmony_ci async onBackup() { 37e41f4b71Sopenharmony_ci console.log("onBackup begin"); 38e41f4b71Sopenharmony_ci // 使用者可通过改变 this.context.area 来进行切换el1,el2对应的沙箱路径 39e41f4b71Sopenharmony_ci this.context.area = contextConstant.AreaMode.EL1; 40e41f4b71Sopenharmony_ci // 使用者可通过 this.context.backupDir 对沙箱路径进行获取 41e41f4b71Sopenharmony_ci let dir = this.context.backupDir; 42e41f4b71Sopenharmony_ci console.log(`onBackup el1 dir: ${dir}`); 43e41f4b71Sopenharmony_ci this.context.area = contextConstant.AreaMode.EL2; 44e41f4b71Sopenharmony_ci dir = this.context.backupDir; 45e41f4b71Sopenharmony_ci console.log(`onBackup el2 dir: ${dir}`); 46e41f4b71Sopenharmony_ci console.log("onBackup end"); 47e41f4b71Sopenharmony_ci } 48e41f4b71Sopenharmony_ci 49e41f4b71Sopenharmony_ci async onRestore() { 50e41f4b71Sopenharmony_ci console.log("onRestore begin"); 51e41f4b71Sopenharmony_ci this.context.area = contextConstant.AreaMode.EL1; 52e41f4b71Sopenharmony_ci let dir = this.context.backupDir; 53e41f4b71Sopenharmony_ci console.log(`onRestore el1 dir: ${dir}`); 54e41f4b71Sopenharmony_ci this.context.area = contextConstant.AreaMode.EL2; 55e41f4b71Sopenharmony_ci dir = this.context.backupDir; 56e41f4b71Sopenharmony_ci console.log(`onRestore el2 dir: ${dir}`); 57e41f4b71Sopenharmony_ci console.log("onRestore end"); 58e41f4b71Sopenharmony_ci } 59e41f4b71Sopenharmony_ci} 60e41f4b71Sopenharmony_ci``` 61e41f4b71Sopenharmony_ci 62e41f4b71Sopenharmony_ci 63