harmony-utils之PermissionUtil,授权相关工具类

简介: harmony-utils之PermissionUtil是HarmonyOS授权工具类,提供申请、校验及二次授权等方法,支持单个或多个权限操作,简化鸿蒙应用权限管理流程。

harmony-utils之PermissionUtil,授权相关工具类

harmony-utils 简介与说明


harmony-utils 一款功能丰富且极易上手的HarmonyOS工具库,借助众多实用工具类,致力于助力开发者迅速构建鸿蒙应用。其封装的工具涵盖了APP、设备、屏幕、授权、通知、线程间通信、弹框、吐司、生物认证、用户首选项、拍照、相册、扫码、文件、日志,异常捕获、字符、字符串、数字、集合、日期、随机、base64、加密、解密、JSON等一系列的功能和操作,能够满足各种不同的开发需求。
picker_utils 是harmony-utils拆分出来的一个子库,包含PickerUtil、PhotoHelper、ScanUtil。

下载安装
ohpm i @pura/harmony-utils
ohpm i @pura/picker_utils

  //全局初始化方法,在UIAbility的onCreate方法中初始化 AppUtil.init()
  onCreate(want: Want, launchParam: AbilityConstant.LaunchParam): void {
    AppUtil.init(this.context);
  }

API方法与使用


requestPermissionsEasy 申请授权,拒绝后并二次向用户申请授权(申请权限,建议使用该方法)
let p: Permissions[] = ['ohos.permission.ACTIVITY_MOTION', 'ohos.permission.CAMERA', 'ohos.permission.LOCATION', 'ohos.permission.APPROXIMATELY_LOCATION'];
PermissionUtil.requestPermissionsEasy(p).then((result) => {
  ToastUtil.showToast(`申请授权,结果:${result}`);
})
checkPermissions 校验当前是否已经授权
let p: Permissions = 'ohos.permission.CAMERA'; //相机
PermissionUtil.checkPermissions(p).then((result) => {
ToastUtil.showToast(`检测是否授权,结果:${result}`);
})
checkRequestPermissions 校验是否授权后并申请授权
let p: Permissions = 'ohos.permission.CAMERA'; //相机
PermissionUtil.checkRequestPermissions(p).then((grant) => {
  ToastUtil.showToast(`检测并申请授权,结果:${grant}`);
  if (!grant) {
    WantUtil.toAppSetting(); //拒绝权限,跳转APP设置页面
  }
})
requestPermissions 申请授权
let p: Permissions[] = ['ohos.permission.ACTIVITY_MOTION', 'ohos.permission.CAMERA','ohos.permission.LOCATION', 'ohos.permission.APPROXIMATELY_LOCATION'];
PermissionUtil.requestPermissions(p).then((grant) => {
  if (grant) {
    ToastUtil.showToast(`申请授权,已通过...`);
  } else { //拒绝权限,二次向用户申请授权
    PermissionUtil.requestPermissionOnSettingEasy(p).then((result) => {
      ToastUtil.showToast(`申请授权,结果:${result}`);
    });
  }
})
requestPermissionOnSetting 二次向用户申请授权(单个权限 或 读写权限组,建议使用该方法)
let ps: Permissions[] = ['ohos.permission.READ_IMAGEVIDEO', 'ohos.permission.WRITE_IMAGEVIDEO'];
PermissionUtil.requestPermissions(ps).then((result) => {
  if (result) {
    ToastUtil.showToast(`最佳使用案例授权,已通过...`);
  } else {
    PermissionUtil.requestPermissionOnSetting(ps).then((grant) => {
      ToastUtil.showToast(`最佳使用案例,结果:${grant}`);
    })
  }
})
requestPermissionOnSettingEasy 二次向用户申请授权(多个权限建议使用该方法)
let p: Permissions[] = ['ohos.permission.ACTIVITY_MOTION', 'ohos.permission.CAMERA','ohos.permission.LOCATION', 'ohos.permission.APPROXIMATELY_LOCATION'];
PermissionUtil.requestPermissions(p).then((grant) => {
  if (grant) {
    ToastUtil.showToast(`申请授权,已通过...`);
  } else { //拒绝权限,二次向用户申请授权
    PermissionUtil.requestPermissionOnSettingEasy(p).then((result) => {
      ToastUtil.showToast(`申请授权,结果:${result}`);
    });
  }
})
requestGlobalSwitch 用于UIAbility/UIExtensionAbility拉起全局开关设置弹框。部分情况下,录音、拍照等功能禁用,应用可拉起此弹框请求用户同意开启对应功能。如果当前全局开关的状态为开启,则不拉起弹框
PermissionUtil.requestGlobalSwitch(abilityAccessCtrl.SwitchType.LOCATION).then((result) => {
  ToastUtil.showToast(`申请结果:${result}`);
}).catch((err: BusinessError) => {
  ToastUtil.showToast(err.message);
  LogUtil.error(err);
});

创作不易,请给童长老点赞👍


https://github.com/787107497/harmony-utils
https://gitee.com/tongyuyan/harmony-utils
OpenHarmony三方库

目录
相关文章
|
3月前
|
JSON 生物认证 API
harmony-utils之PasteboardUtil,剪贴板工具类
harmony-utils 是一款功能丰富且易用的 HarmonyOS 工具库,提供剪贴板、设备、屏幕、授权等常用工具类,助力开发者高效构建鸿蒙应用。
118 0
|
3月前
|
JSON 生物认证 API
harmony-utils之LogUtil,日志工具类
harmony-utils 是一款功能强大的 HarmonyOS 工具库,涵盖日志、设备、通知、文件等常用开发模块。其中 LogUtil 提供丰富的日志操作方法,支持 DEBUG、INFO、WARN、ERROR、FATAL 等级别日志打印,便于开发者调试与维护应用,助力高效开发。
138 0
|
3月前
|
JSON 生物认证 API
harmony-utils之LocationUtil,定位相关工具类
harmony-utils 是一款专为 HarmonyOS 开发的高效工具库,包含丰富的实用类与功能模块。其中 LocationUtil 提供了定位服务判断、权限申请、位置获取、地理编码、坐标转换等功能,帮助开发者快速实现定位相关操作,提升开发效率。
133 0
|
3月前
|
JSON 安全 生物认证
harmony-utils之RandomUtil,随机工具类
harmony-utils 是一款功能强大的 HarmonyOS 工具库,提供丰富的实用类与方法,助力开发者高效构建鸿蒙应用。其中 RandomUtil 类可生成随机布尔值、整数、字符串、汉字、颜色、UUID 等,支持多种随机数据生成场景,使用简单,适用于测试、安全、界面展示等多种用途。
153 0
|
3月前
|
JSON 生物认证 API
harmony-utils之ObjectUtil,对象工具类
`harmony-utils` 是一款专为 HarmonyOS 开发的功能强大且易于使用的工具库,涵盖对象操作、设备信息、文件处理、数据加密等常用开发功能,帮助开发者快速构建高效稳定的鸿蒙应用。
132 0
|
3月前
|
JSON 生物认证 API
harmony-utils之FormatUtil,格式化工具类
FormatUtil 是 harmony-utils 工具库中的格式化工具类,提供电话号码验证与格式化、中文转拼音、百分比显示、文件大小转换、文本截取、URL参数解析与拼接等功能,助力鸿蒙应用快速开发。
132 0
|
3月前
|
JSON 生物认证 API
harmony-utils之EmitterUtil,Emitter工具类
harmony-utils之EmitterUtil是一款HarmonyOS应用开发中的事件通信工具类,支持事件的发送、订阅、单次订阅、取消订阅及订阅数查询等操作。它基于高效的事件驱动机制,简化了模块间的通信流程,提升开发效率,适用于复杂场景下的事件管理。
140 0
|
3月前
|
JSON 生物认证 API
harmony-utils之PreviewUtil,文件预览工具类
PreviewUtil 是 harmony-utils 工具库中的文件预览工具类,提供生成预览信息、打开/关闭预览窗口、加载预览数据、判断预览支持等功能,助力鸿蒙应用快速实现文件预览操作。
226 0
|
3月前
|
JSON 安全 生物认证
harmony-utils之NumberUtil,Number工具类
NumberUtil 是 HarmonyOS 工具库 harmony-utils 中的数字工具类,提供丰富的数值处理方法,如判断NaN、有限数、整数、安全整数、奇偶性,数值转换、加减乘除及求和等,助力高效开发。
162 0
|
3月前
|
JSON 生物认证 API
harmony-utils之NotificationUtil,通知工具类
harmony-utils 是一款功能丰富的 HarmonyOS 工具库,提供通知、设备、文件等常用工具类。NotificationUtil 作为其子模块,专注于通知管理,支持普通、多行、长文本、图片及模板通知的发布与管理,简化鸿蒙应用开发流程。
133 0