十念 发表于 2024-6-22 13:01:52

2024年HarmonyOS鸿蒙最新HarmonyOS 应用开发之应用上下文Context(3),2024

深知大多数程序员,想要提升技能,每每是本身摸索成长,但本身不成体系的自学效果低效又漫长,而且极易碰到天花板技能故步自封!
https://img-blog.csdnimg.cn/direct/743b668910224b259a5ffe804fa6d0db.png
https://img-blog.csdnimg.cn/img_convert/8848531aa62959c3b519414cc5bded52.png
https://img-blog.csdnimg.cn/img_convert/a08e602cc81cf475eb4269c1a0d5fdb1.png
既有适合小白学习的零根本资料,也有适合3年以上履历的小伙伴深入学习提升的进阶课程,涵盖了95%以上鸿蒙开发知识点,真正体系化!
由于文件比力多,这里只是将部门目录截图出来,全套包含大厂面经、学习笔记、源码课本、实战项目、大纲蹊径、讲解视频,而且后续会一连更新
需要这份体系化的资料的朋侪,可以戳这里获取
| preferencesDir | <路径前缀>/<加密品级>/base/haps//preferences |
| tempDir | <路径前缀>/<加密品级>/base/haps//temp |
| databaseDir | <路径前缀>/<加密品级>/database/ |
| distributedFilesDir | <路径前缀>/el2/distributedFiles/ |
示例代码如下所示。
import common from '@ohos.app.ability.common';
import hilog from '@ohos.hilog';
import promptAction from '@ohos.promptAction';

const TAG: string = '';
const DOMAIN_NUMBER: number = 0xFF00;
@Entry
@Component
struct Page_Context {

private context = getContext(this) as common.UIAbilityContext;

build() {
    ...
    Button()
      .onClick(() => {
      let cacheDir = this.context.cacheDir;
      let tempDir = this.context.tempDir;
      let filesDir = this.context.filesDir;
      let databaseDir = this.context.databaseDir;
      let bundleCodeDir = this.context.bundleCodeDir;
      let distributedFilesDir = this.context.distributedFilesDir;
      let preferencesDir = this.context.preferencesDir;
      // 获取应用文件路径
      let filePath = tempDir + 'test.txt';
      hilog.info(DOMAIN_NUMBER, TAG, `filePath: ${filePath}`);
      if (filePath !== null) {
          promptAction.showToast({
            message: filePath
          });
      }
      })
}
}

获取和修改加密分区

应用文件加密是一种掩护数据安全的方法,可以使得文件在未经授权访问的情况下得到掩护。在不同的场景下,应用需要不同水平的文件掩护。
在实际应用中,开发者需要根据不同场景的需求选择合适的加密分区,从而掩护应用数据的安全。通过合理使用不同级别的加密分区,可以有效提高应用数据的安全性。关于不同分区的权限阐明。


[*]EL1:对于私有文件,如闹铃、壁纸等,应用可以将这些文件放到设备级加密分区(EL1)中,以包管在用户输入密码前就可以被访问。
[*]EL2:对于更敏感的文件,如个人隐私信息等,应用可以将这些文件放到更高级别的加密分区(EL2)中,以包管更高的安全性。
[*]EL3:对于应用中的记录步数、文件下载、音乐播放,需要在锁屏时读写和创建新文件,放在(EL3)的加密分区比力合适。
[*]EL4:对于用户安全信息相关的文件,锁屏时不需要读写文件、也不能创建文件,放在(EL4)的加密分区更合适。
要实现获取和设置当前加密分区,可以通过读写Context的area属性来实现。
import UIAbility from '@ohos.app.ability.UIAbility';
import contextConstant from '@ohos.app.ability.contextConstant';
import AbilityConstant from '@ohos.app.ability.AbilityConstant';
import Want from '@ohos.app.ability.Want';

export default class EntryAbility extends UIAbility {
onCreate(want: Want, launchParam: AbilityConstant.LaunchParam) {
    // 存储普通信息前,切换到EL1设备级加密
    this.context.area = contextConstant.AreaMode.EL1; // 切换area
    // 存储普通信息

    // 存储敏感信息前,切换到EL2用户级加密
    this.context.area = contextConstant.AreaMode.EL2; // 切换area
    // 存储敏感信息

    // 存储敏感信息前,切换到EL3用户级加密
    this.context.area = contextConstant.AreaMode.EL3; // 切换area
    // 存储敏感信息

    // 存储敏感信息前,切换到EL4用户级加密
    this.context.area = contextConstant.AreaMode.EL4; // 切换area
    // 存储敏感信息
}
}

import contextConstant from '@ohos.app.ability.contextConstant';
import common from '@ohos.app.ability.common';
import promptAction from '@ohos.promptAction';

@Entry
@Component
struct Page_Context {

private context = getContext(this) as common.UIAbilityContext;

build() {
    ...
    Button()
      .onClick(() => {
      // 存储普通信息前,切换到EL1设备级加密
      if (this.context.area === contextConstant.AreaMode.EL2) { // 获取area
          this.context.area = contextConstant.AreaMode.EL1; // 修改area
          promptAction.showToast({
            message: $r('app.string.SwitchToEL1')
          });
      }
      // 存储普通信息
      })
   
    ...

    Button()
      .onClick(() => {
      // 存储敏感信息前,切换到EL2用户级加密
      if (this.context.area === contextConstant.AreaMode.EL1) { // 获取area
          this.context.area = contextConstant.AreaMode.EL2; // 修改area
          promptAction.showToast({
            message: $r('app.string.SwitchToEL2')
          });
      }
      // 存储敏感信息
      })
   
    ...
}
}

创建其他应用或其他Module的Context

基类Context提供创建其他应用或其他Module的Context的方法有 createBundleContext(bundleName: string) 、createModuleContext(moduleName: string) 和createModuleContext(bundleName: string, moduleName: string)接口,创建其他应用或者其他Module的Context,从而通过该Context获取相应的资源信息(比方获取其他Module的 获取应用文件路径信息)。


[*]调用createBundleContext(bundleName:string)方法,创建其他应用的Context信息。
   阐明:
当获取的是其他应用的Context时:


[*]申请ohos.permission.GET_BUNDLE_INFO_PRIVILEGED权限,配置方式请参见 申请应用权限 。
[*]接口为体系接口,三方应用不支持调用。
比方在桌面上表现的应用信息,包罗应用名称和应用图标等,桌面应用可以通过调用上述的方法获取相应应用的Context信息从而获取到相应的应用名称、图标等资源信息。
import promptAction from '@ohos.promptAction';
import common from '@ohos.app.ability.common';

let storageEventCall = new LocalStorage();

@Entry(storageEventCall)
@Component
struct Page_ContextAbility {
private context = getContext(this) as common.UIAbilityContext;
build() {
    Button()
      .onClick(() => {
      let bundleName2: string = 'com.samples.stagemodelabilityinteraction';
      let bundleContext: Context = this.context.createBundleContext(bundleName2);
      let label2: string = bundleContext.applicationInfo.label;
      if (bundleContext && label2 !== null) {
          promptAction.showToast({
            message: ('成功获取Context')
          });
      }
      })
}
}



[*]调用createModuleContext(bundleName:string, moduleName:string)方法,获取指定应用指定Module的上下文信息。获取到指定应用指定Module的Context之后,即可获取到相应应用Module的资源信息。
   阐明:
当获取的是其他应用的指定Module的Context时:


[*]申请ohos.permission.GET_BUNDLE_INFO_PRIVILEGED权限,配置方式请参见 申请应用权限 。
[*]接口为体系接口,三方应用不支持调用。
import promptAction from '@ohos.promptAction';
import common from '@ohos.app.ability.common';

let storageEventCall = new LocalStorage();

@Entry(storageEventCall)
@Component
struct Page_ContextAbility {
private context = getContext(this) as common.UIAbilityContext;
build() {
    Button()
      .onClick(() => {
      let bundleName2: string = 'com.samples.stagemodelabilityinteraction';
      let moduleName2: string= 'entry';
      let moduleContext = this.context.createModuleContext(bundleName2, moduleName2);
      if (moduleContext !== null) {
          promptAction.showToast({
            message: ('成功获取Context')
          });
      }
      })
}
}



[*]调用createModuleContext(moduleName:string)方法,获取本应用中其他Module的Context。获取到其他Module的Context之后,即可获取到相应Module的资源信息。
mport promptAction from '@ohos.promptAction';
import common from '@ohos.app.ability.common';

let storageEventCall = new LocalStorage();

@Entry(storageEventCall)
@Component
struct Page_ContextAbility {
private context = getContext(this) as common.UIAbilityContext;
build() {
    Button()
      .onClick(() => {
      let moduleName2: string = 'entry';
      let moduleContext: Context = this.context.createModuleContext(moduleName2);
      if (moduleContext !== null) {
          promptAction.showToast({
            message: ('成功获取Context')
          });
      }
      })
}
}

订阅进程内UIAbility生命周期变化

在应用内的DFX统计场景中,如需要统计对应页面停顿时间和访问频率等信息,可以使用订阅进程内UIAbility生命周期变化功能。
通过 ApplicationContext 提供的本领,可以订阅进程内UIAbility生命周期变化。当进程内的UIAbility生命周期变化时,如创建、可见/不可见、获焦/失焦、销毁等,会触发相应的回调函数。每次注册回调函数时,都会返回一个监听生命周期的ID,此ID会自增+1。当超过监听上限数量2^63-1时,会返回-1。以 UIAbilityContext 中的使用为例进行阐明。
import type AbilityConstant from '@ohos.app.ability.AbilityConstant';
import type AbilityLifecycleCallback from '@ohos.app.ability.AbilityLifecycleCallback';
import hilog from '@ohos.hilog';
import UIAbility from '@ohos.app.ability.UIAbility';
import type Want from '@ohos.app.ability.Want';
import type window from '@ohos.window';

const TAG: string = '';
const DOMAIN_NUMBER: number = 0xFF00;

export default class LifecycleAbility extends UIAbility {
// 定义生命周期ID
lifecycleId: number = -1;

onCreate(want: Want, launchParam: AbilityConstant.LaunchParam): void {
    // 定义生命周期回调对象
    let abilityLifecycleCallback: AbilityLifecycleCallback = {
      // 当UIAbility创建时被调用
      onAbilityCreate(uiAbility) {
      hilog.info(DOMAIN_NUMBER, TAG, `onAbilityCreate uiAbility.launchWant: ${JSON.stringify(uiAbility.launchWant)}`);
      },
      // 当窗口创建时被调用
      onWindowStageCreate(uiAbility, windowStage: window.WindowStage) {
      hilog.info(DOMAIN_NUMBER, TAG, `onWindowStageCreate uiAbility.launchWant: ${JSON.stringify(uiAbility.launchWant)}`);
      hilog.info(DOMAIN_NUMBER, TAG, `onWindowStageCreate windowStage: ${JSON.stringify(windowStage)}`);
      },
      // 当窗口处于活动状态时被调用
      onWindowStageActive(uiAbility, windowStage: window.WindowStage) {
      hilog.info(DOMAIN_NUMBER, TAG, `onWindowStageActive uiAbility.launchWant: ${JSON.stringify(uiAbility.launchWant)}`);
      hilog.info(DOMAIN_NUMBER, TAG, `onWindowStageActive windowStage: ${JSON.stringify(windowStage)}`);
      },
      // 当窗口处于非活动状态时被调用
      onWindowStageInactive(uiAbility, windowStage: window.WindowStage) {
      hilog.info(DOMAIN_NUMBER, TAG, `onWindowStageInactive uiAbility.launchWant: ${JSON.stringify(uiAbility.launchWant)}`);
      hilog.info(DOMAIN_NUMBER, TAG, `onWindowStageInactive windowStage: ${JSON.stringify(windowStage)}`);
      },
      // 当窗口被销毁时被调用
      onWindowStageDestroy(uiAbility, windowStage: window.WindowStage) {
      hilog.info(DOMAIN_NUMBER, TAG, `onWindowStageDestroy uiAbility.launchWant: ${JSON.stringify(uiAbility.launchWant)}`);
      hilog.info(DOMAIN_NUMBER, TAG, `onWindowStageDestroy windowStage: ${JSON.stringify(windowStage)}`);
      },
      // 当UIAbility被销毁时被调用
      onAbilityDestroy(uiAbility) {
      hilog.info(DOMAIN_NUMBER, TAG, `onAbilityDestroy uiAbility.launchWant: ${JSON.stringify(uiAbility.launchWant)}`);
      },
      // 当UIAbility从后台转到前台时触发回调
      onAbilityForeground(uiAbility) {
      hilog.info(DOMAIN_NUMBER, TAG, `onAbilityForeground uiAbility.launchWant: ${JSON.stringify(uiAbility.launchWant)}`);
      },
      // 当UIAbility从前台转到后台时触发回调
      onAbilityBackground(uiAbility) {
      hilog.info(DOMAIN_NUMBER, TAG, `onAbilityBackground uiAbility.launchWant: ${JSON.stringify(uiAbility.launchWant)}`);
      },
      // 当UIAbility迁移时被调用
      onAbilityContinue(uiAbility) {
      hilog.info(DOMAIN_NUMBER, TAG, `onAbilityContinue uiAbility.launchWant: ${JSON.stringify(uiAbility.launchWant)}`);
      }
    };
    // 获取应用上下文
    let applicationContext = this.context.getApplicationContext();
    // 注册应用内生命周期回调
    this.lifecycleId = applicationContext.on('abilityLifecycle', abilityLifecycleCallback);
    hilog.info(DOMAIN_NUMBER, TAG, `register callback number: ${this.lifecycleId}`);
}

...

onDestroy() : void {
    // 获取应用上下文
    let applicationContext = this.context.getApplicationContext();
    // 取消应用内生命周期回调
    applicationContext.off('abilityLifecycle', this.lifecycleId);
}
};

为了能让各人更好的学习鸿蒙(HarmonyOS NEXT)开发技能,这边特意整理了《鸿蒙开发学习手册》(共计890页),希望对各人有所帮助:https://qr21.cn/FV7h05
《鸿蒙开发学习手册》:

如何快速入门:https://qr21.cn/FV7h05


[*]根本概念
[*]构建第一个ArkTS应用
[*]……
https://img-blog.csdnimg.cn/img_convert/afd6b98a09014e557566dec0fd065c41.webp?x-oss-process=image/format,png
开发根本知识:https://qr21.cn/FV7h05


[*]应用根本知识
[*]配置文件
[*]应用数据管理
[*]应用安全管理
https://img-blog.csdnimg.cn/img_convert/5dcae7bb98eb26c77bc4d30ede10be5c.png
https://img-blog.csdnimg.cn/img_convert/a7e37c7bba19b09c65aa42767730a75b.png
网上学习资料一大堆,但如果学到的知识不成体系,遇到题目时只是浅尝辄止,不再深入研究,那么很难做到真正的技能提升。
需要这份体系化的资料的朋侪,可以戳这里获取
一个人可以走的很快,但一群人才气走的更远!岂论你是正从事IT行业的老鸟或是对IT行业感爱好的新人,都接待加入我们的的圈子(技能交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
识:https://qr21.cn/FV7h05**

[*]应用根本知识
[*]配置文件
[*]应用数据管理
[*]应用安全管理
[外链图片转存中…(img-eUt6qooT-1715629502015)]
[外链图片转存中…(img-LfVHd4Dd-1715629502015)]
网上学习资料一大堆,但如果学到的知识不成体系,遇到题目时只是浅尝辄止,不再深入研究,那么很难做到真正的技能提升。
需要这份体系化的资料的朋侪,可以戳这里获取
一个人可以走的很快,但一群人才气走的更远!岂论你是正从事IT行业的老鸟或是对IT行业感爱好的新人,都接待加入我们的的圈子(技能交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页: [1]
查看完整版本: 2024年HarmonyOS鸿蒙最新HarmonyOS 应用开发之应用上下文Context(3),2024