HarmonyOS 鸿蒙Next 避免涉及口令输入的应用界面可以被截屏或录屏

发布于 1周前 作者 sinazl 最后一次编辑是 5天前 来自 鸿蒙OS

HarmonyOS 鸿蒙Next 避免涉及口令输入的应用界面可以被截屏或录屏

import { BusinessError } from '@kit.BasicServicesKit';
import { window } from "@kit.ArkUI";

let isPrivacyMode: boolean = true;
let windowClass: window.Window = window.findWindow("test");
let promise = windowClass.setWindowPrivacyMode(isPrivacyMode); // 设置防截屏录屏
promise.then(() => {
  console.info('Succeeded in setting the window to privacy mode.');
}).catch((err: BusinessError) => {
  console.error(`ErrorCode: ${err.code}, Message: ${err.message}`);
})

更多关于HarmonyOS 鸿蒙Next 避免涉及口令输入的应用界面可以被截屏或录屏的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html

4 回复

一些页面需要实现防截屏功能。首先需要在module.json5中申请隐私窗口权限。 然后在onPageShow()中获取当前窗口对象并设置隐私模式。 在退出页面的时候,在onPageHide()生命周期中取消隐私模式即可。

参考文档:https://developer.huawei.com/consumer/cn/doc/harmonyos-references-V5/js-apis-window-V5

参考代码:

//module.json5文件中
{
  "name" : 'ohos.permission.PRIVACY_WINDOW'
}

//EAbility文件中

onWindowStageCreate(windowStage: window.WindowStage): void {
  let windowClass: window.Window = windowStage.getMainWindowSync();
  // 获取应用主窗口

  AppStorage.setOrCreate("windowClass",windowClass);
}


//Index文件中

import { window } from '@kit.ArkUI';
import { BusinessError } from '@ohos.base';

@Entry
@Component
struct Index43 {
  private windowStage = AppStorage.get("windowStage") as window.WindowStage
  private windowClass = AppStorage.get("windowClass") as window.Window
  @State message: string = 'Hello World';



  build() {
    Row() {
      Column() {
        Text('禁止截屏')
          .fontSize(50)
          .fontWeight(FontWeight.Bold)
          .onClick(() => {

            let isPrivacyMode: boolean = true;
            try {
              this.windowClass.setWindowPrivacyMode(isPrivacyMode, (err: BusinessError) => {
                const errCode: number = err.code;
                if (errCode) {
                  console.error('Failed to set the window to privacy mode. Cause:' + JSON.stringify(err));
                  return;
                }
                console.info('Succeeded in setting the window to privacy mode.');
              });
            } catch (exception) {
              console.error('Failed to set the window to privacy mode. Cause:' + JSON.stringify(exception));
            }
          })


        Text('允许截屏')
          .fontSize(50)
          .fontWeight(FontWeight.Bold)
          .onClick(() => {

            let isPrivacyMode: boolean = false;
            try {
              this.windowClass.setWindowPrivacyMode(isPrivacyMode, (err: BusinessError) => {
                const errCode: number = err.code;
                if (errCode) {
                  console.error('Failed to set the window to privacy mode. Cause:' + JSON.stringify(err));
                  return;
                }
                console.info('Succeeded in setting the window to privacy mode.');
              });
            } catch (exception) {
              console.error('Failed to set the window to privacy mode. Cause:' + JSON.stringify(exception));
            }
          })

      }
      .width('100%')
    }
    .height('100%')
  }
}

更多关于HarmonyOS 鸿蒙Next 避免涉及口令输入的应用界面可以被截屏或录屏的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html


获取windowClass的方式需要调整下

深色代码主题
复制
            let isPrivacyMode: boolean = true;
            let windowClass = window.getLastWindow(getContext(this));
            windowClass.then((windowStage: window.Window) => {
                  windowStage.setWindowPrivacyMode(isPrivacyMode).then(() => {
                    console.info('Succeeded in setting the window to privacy mode.');
                  }).catch((err: BusinessError) => {
                    console.error(`ErrorCode: ${err.code}, Message: ${err.message}`);
                  });
            });
深色代码主题
复制
  //防截屏
  onPageShow() {
    window.getLastWindow(getContext(this)).then((windowStage: window.Window) => {
      windowStage.setWindowPrivacyMode(true);
    });
  }

onPageHide() { window.getLastWindow(getContext(this)).then((windowStage: window.Window) => { windowStage.setWindowPrivacyMode(false); }); }

在页面生命周期onPageShow()、onPageHide()里面调用

HarmonyOS 鸿蒙Next系统中,为避免涉及口令输入的应用界面被截屏或录屏,系统提供了一系列的安全机制和控制接口。

首先,鸿蒙系统内置了屏幕录制和截屏的权限管理,开发者可以在应用内通过调用系统API,明确禁止或限制特定页面的截屏和录屏功能。具体实现方式是,在涉及敏感信息(如密码、支付验证码等)显示的页面,开发者可以调用disableScreenCapture()disableScreenRecord()接口,来禁止当前页面的屏幕捕获和录制。

此外,鸿蒙系统还支持基于应用级别的权限控制,用户可以在系统设置中,为单个应用开启或关闭截屏和录屏权限,进一步提升了用户隐私的保护力度。

同时,鸿蒙系统提供了应用级别的安全提示机制,当应用检测到有截屏或录屏行为时,可以通过系统提示用户当前有屏幕捕获或录制行为,让用户及时做出反应。

最后,鸿蒙系统还提供了安全审计和日志记录功能,帮助开发者追踪和审计应用内的截屏和录屏行为,确保应用安全合规。

如果问题依旧没法解决请联系官网客服,官网地址是:https://www.itying.com/category-93-b0.html

回到顶部