HarmonyOS 鸿蒙Next如何做口令输入界面防截屏/录屏

发布于 1周前 作者 caililin 来自 鸿蒙OS

HarmonyOS 鸿蒙Next如何做口令输入界面防截屏/录屏 请问下,口令输入页面需要加下防截屏/录屏,代码怎么实现? 看文档不太明白

3 回复

一些页面需要实现防截屏功能。首先需要在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));
            }
          })
      }
    }
  }
}

更多关于HarmonyOS 鸿蒙Next如何做口令输入界面防截屏/录屏的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html


HarmonyOS 鸿蒙Next系统中,实现口令输入界面防截屏/录屏功能,可以通过以下方式进行处理:

  1. 使用系统API检测截屏/录屏状态:鸿蒙系统提供了相应的API来检测当前设备是否正在进行截屏或录屏操作。开发者可以在口令输入界面调用这些API,当检测到截屏或录屏行为时,采取相应措施,如隐藏或模糊输入内容。

  2. 自定义输入控件:为了进一步增强安全性,可以自定义输入控件,使其在被截屏或录屏时自动显示占位符或干扰信息,而非真实的输入内容。

  3. 权限管理:通过应用权限管理,限制其他应用访问屏幕内容的权限,特别是在口令输入界面时。这可以减少截屏或录屏软件获取敏感信息的机会。

  4. 用户提示:在口令输入界面添加提示信息,告知用户当前界面禁止截屏和录屏,并引导用户检查设备的状态栏或通知栏,确保没有启用相关功能。

  5. 利用系统级防护机制:鸿蒙系统可能内置了防截屏/录屏的机制,开发者可以查阅官方文档,了解并利用这些系统级功能来增强应用的安全性。

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

回到顶部