HarmonyOS申请用户位置信息授权和再次授权-系统级API获取地理位置的错误码类型问题getCurrentLocation()

应用场景

在许多的app中,都需要用到获取用户的地理位置这一功能,由于地理位置属于隐私级别较高的系统能力,所以要申请用户授权,但是在用户授权时,可能出现多种场景,用户不授权,用户授权了但是系统的定位功能没有打开,用户授权了但是由于其他因素(网络问题)导致的获取定位失败。在用户拒绝授权后,怎样再次发起二次授权请求。

不同API的二次授权方式不同

打开设置页面,二次申请权限,通过UIAbilityContext.startAbility的固定写法打开设置页

  1. .onClick(async () => {

  2. const context = getContext() as common.UIAbilityContext

  3. const bundleInfo =

  4. bundleManager.getBundleInfoForSelfSync(bundleManager.BundleFlag.GET_BUNDLE_INFO_WITH_APPLICATION)

  5. context.startAbility({

  6. bundleName: 'com.huawei.hmos.settings', // 固定写法CV:设置页的包名

  7. abilityName: 'com.huawei.hmos.settings.MainAbility', // 固定写法CV:设置页的 ability 名

  8. uri: 'application_info_entry', // 固定写法CV:打开 设置->应用和元服务

  9. parameters: {

  10. // 按照包名打开对应设置页

  11. pushParams: bundleInfo.name

根据返回值继续打开模态框的方法abilityAccessCtrl.requestPermissionsFromUser()

  1. // 核心API: requestPermissionsFromUser()

  2. const atManager = abilityAccessCtrl.createAtManager()

  3. const result = await atManager.requestPermissionsFromUser(getContext(), ['ohos.permission.READ_CALENDAR'])

  4. AlertDialog.show({ message: JSON.stringify(result, null, 2) })

  5. if (result.authResults.includes(-1) && result.dialogShownResults?.includes(false)) {

  6. atManager.requestPermissionOnSetting(getContext(), ['ohos.permission.READ_CALENDAR'])

错误码返回值类型“坑”点

首先这里我们用的是动态根据返回值来判断用户是否有权限,是否需要打开二次授权的弹窗。

这里的geoLocationManager.getCurrentLocation()如果失败,通过catch捕获错误,打印错误码发现,

//{"code": 201 }      用户未授权或拒绝授权
//  {"code": "3301100" }  位置功能的开关未开启,模拟器下拉控制中心,打开定位开关 //  {"code": 3301200 }  定位失败,未获取到定位结果

错误码201是数字类型,"3301100"是字符串,3301200又是数字类型,所以很容易在判断时产生错误,导致逻辑失败,所以要对错误码强制类型转换进行统一类型

Number((err as BusinessError).code),然后进行判断,根据不同类型决定要提醒用户还是打开二次授权申请

  1. const manager = abilityAccessCtrl.createAtManager()

  2. manager.requestPermissionsFromUser(getContext(), [

  3. 'ohos.permission.APPROXIMATELY_LOCATION'

  4. .onClick(async () => {
  5. const res = await geoLocationManager.getCurrentLocation()

  6. promptAction.showToast({ message: JSON.stringify(res) })

  7. } catch (err) {

  8. console.log('wgt666', JSON.stringify(err))

  9. // {"code": 201 } 用户未授权或拒绝授权

  10. // {"code": "3301100" } 位置功能的开关未开启,模拟器下拉控制中心,打开定位开关

  11. // {"code": 3301200 } 定位失败,未获取到定位结果

  12. // switch 处理错误情况,code 数据类型有坑

  13. switch (Number((err as BusinessError).code)) {

  14. case 201: {

  15. const manager = abilityAccessCtrl.createAtManager()

  16. const res = await manager.requestPermissionsFromUser(getContext(), [

  17. 'ohos.permission.APPROXIMATELY_LOCATION',

  18. 'ohos.permission.LOCATION'

  19. // promptAction.showToast({ message: JSON.stringify(res) })

  20. // 当用户拒绝授权后,再次点击,会返回false,此时需要引导用户去设置页面手动授权

  21. if (res.authResults.includes(-1) && res.dialogShownResults?.includes(false)) {

  22. manager.requestPermissionOnSetting(getContext(), [

  23. 'ohos.permission.APPROXIMATELY_LOCATION',

  24. 'ohos.permission.LOCATION'

  25. case 3301100: {

  26. promptAction.showToast({ message: '位置权限未开启' })

  27. promptAction.showToast({ message: '获取位置失败' })
  28. const manager = abilityAccessCtrl.createAtManager()

  29. bundleManager.getBundleInfoForSelfSync(bundleManager.BundleFlag.GET_BUNDLE_INFO_WITH_APPLICATION)

  30. manager.checkAccessTokenSync(bundle.appInfo.accessTokenId, 'ohos.permission.APPROXIMATELY_LOCATION')

  31. promptAction.showToast({ message: res.toString() })

本文使用 文章同步助手 同步

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容