华为应用权限初次申请及二次申请

应用权限概述

系统提供了一种允许应用访问系统资源(如:通讯录等)和系统能力(如:访问摄像头、麦克风等)的通用权限访问方式,来保护系统数据(包括用户个人数据)或功能,避免它们被不当或恶意使用。

应用申请敏感权限时,必须填写权限使用理由字段,敏感权限通常是指与用户隐私密切相关的权限,包括地理位置、相机、麦克风、日历、健身运动、身体传感器、音乐、文件、图片视频等权限。参考向用户申请授权。

system_grant
在配置文件中,声明应用需要请求的权限后,系统会在安装应用时自动为其进行权限预授予,开发者不需要做其他操作即可使用权限。

user_grant

  • 在配置文件中,声明应用需要请求的权限,且要设置需要使用的场景+使用原因
    调用 requestPermissionsFromUser() 方法后,应用程序将等待用户授权的结果。如果用户授权,则可以继续访问目标操作。如果用户拒绝授权,则需要提示用户必须授权才能访问当前页面的功能,并引导用户到系统应用“设置”中打开相应的权限。可参考二次向用户申请权限 requestPermissionOnSetting()

申请权限

首先,在entry/src/main/module.json文件中配置需要申请的权限。
在这里插入图片描述
abilities 同级添加 requestPermissions 字段,并在里面配置权限字段。在这里插入图片描述
在这里插入图片描述
权限描述字段在 main/resources/base/element/string.json 中配置

在这里插入图片描述
可以直接填写,也可以点击Open editor进行 配置
在这里插入图片描述
在这里插入图片描述
至此,基础配置已完成。

封装Permission工具

封装权限工具,提供请求用户权限,拉起用户权限设置的能力。

import { abilityAccessCtrl, Permissions } from '@kit.AbilityKit';

class Permission {
  // 请求用户授权
  async requestPermissions(permissions: Permissions[]) {
    const atManager = abilityAccessCtrl.createAtManager()
    const ctx = AppStorage.get<Context>('context')
    if (ctx) {
      const result = await atManager.requestPermissionsFromUser(ctx, permissions)
      return result.authResults.every(result => result === abilityAccessCtrl.GrantStatus.PERMISSION_GRANTED)
    }
    return false
  }

  // 拉起二次弹窗半模态
  async openPermissionSetting(permissions: Permissions[]) {
    const atManager = abilityAccessCtrl.createAtManager()
    const ctx = AppStorage.get<Context>('context')
    if (ctx) {
      const authResults = await atManager.requestPermissionOnSetting(ctx, permissions)
      return authResults.every(result => result === abilityAccessCtrl.GrantStatus.PERMISSION_GRANTED)
    }
    return false
  }
}

export const permission = new Permission()

之后在需要申请权限的页面进行权限判定。

async aboutToAppear() {

    // 1. 打开授权对话框
    // 2.1 授权,啥也不用干
    // 2.2 禁用,弹出一个对话框,提示用户授权,离开(返回上一个页面)去授权(去应用设置页面)
    try {
      //获取应用获取麦克风权限的结果
      const flag = await permission.requestPermissions(['ohos.permission.MICROPHONE'])
      //如果没有权限
      if (!flag) {
        //自定义弹窗,提醒用户
        const dialogResult = await promptAction.showDialog({
          title: '温馨提示',
          message: '未授权使用麦克风将无法使用该面试录音功能,是否前往设置进行授权?',
          buttons: [
            { text: '离开', color: $r('app.color.common_gray_01') },
            { text: '去授权', color: $r('app.color.black') }
          ],
        })
        //点击“离开”,返回上一个页面
        if (dialogResult.index === 0) {
          router.back()
        } else if (dialogResult.index === 1) {
          //点击授权,跳转至设置页
          const want: Want = {
            bundleName: 'com.huawei.hmos.settings',
            abilityName: 'com.huawei.hmos.settings.MainAbility',
            uri: 'application_info_entry',
            parameters: {
              // 修改成你的应用包名,跳转到该应用的设置页面
              pushParams: '修改成你的应用包名'
            }
          }
          const uiContext = getContext(this) as common.UIAbilityContext
          uiContext.startAbility(want)
        }
      }
    } catch (e) {
      router.back()
    }
  }

总结

如果是 HarmonyOS NEXT Developer Beta3(2024-09-12) 及以上版本,可以在本应用直接拉起二次授权的半模态弹窗,但如果是之前的版本,则需要跳转至设置页进行手动授权。

二次申请的半模态弹窗
在这里插入图片描述
跳转至授权页的弹窗提醒
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值