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