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

应用场景

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

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

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

dart 复制代码
            .onClick(async () => {

              const context = getContext() as common.UIAbilityContext

              const bundleInfo =

                bundleManager.getBundleInfoForSelfSync(bundleManager.BundleFlag.GET_BUNDLE_INFO_WITH_APPLICATION)

              context.startAbility({

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

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

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

                parameters: {

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

                  pushParams: bundleInfo.name

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

scss 复制代码
  //   核心API: requestPermissionsFromUser()

  const atManager = abilityAccessCtrl.createAtManager()

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

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

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

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

错误码返回值类型"坑"点

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

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

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

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

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

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

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

less 复制代码
          const manager = abilityAccessCtrl.createAtManager()

          manager.requestPermissionsFromUser(getContext(), [

            'ohos.permission.APPROXIMATELY_LOCATION'

        .onClick(async () => {

            const res = await geoLocationManager.getCurrentLocation()

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

          } catch (err) {

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

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

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

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

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

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

              case 201: {

                const manager = abilityAccessCtrl.createAtManager()

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

                  'ohos.permission.APPROXIMATELY_LOCATION',

                  'ohos.permission.LOCATION'

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

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

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

                  manager.requestPermissionOnSetting(getContext(), [

                    'ohos.permission.APPROXIMATELY_LOCATION',

                    'ohos.permission.LOCATION'

              case 3301100: {

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

                promptAction.showToast({ message: '获取位置失败' })

          const manager = abilityAccessCtrl.createAtManager()

            bundleManager.getBundleInfoForSelfSync(bundleManager.BundleFlag.GET_BUNDLE_INFO_WITH_APPLICATION)

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

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

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

相关推荐
键盘鼓手苏苏8 小时前
Flutter 三方库 p2plib 的鸿蒙化适配指南 - 实现高性能的端到端(P2P)加密通讯、支持分布式节点发现与去中心化数据流传输实战
flutter·harmonyos·鸿蒙·openharmony
加农炮手Jinx8 小时前
Flutter for OpenHarmony:postgrest 直接访问 PostgreSQL 数据库的 RESTful 客户端(Supabase 核心驱动) 深度解析与鸿蒙适配指南
数据库·flutter·华为·postgresql·restful·harmonyos·鸿蒙
加农炮手Jinx8 小时前
Flutter 组件 heart 适配鸿蒙 HarmonyOS 实战:分布式心跳监控,构建全场景保活检测与链路哨兵架构
flutter·harmonyos·鸿蒙·openharmony
钛态8 小时前
Flutter 三方库 http_mock_adapter — 赋能鸿蒙应用开发的高效率网络接口 Mock 与自动化测试注入引擎(适配鸿蒙 HarmonyOS Next ohos)
android·网络协议·flutter·http·华为·中间件·harmonyos
王码码20358 小时前
Flutter for OpenHarmony:Flutter 三方库 algoliasearch 毫秒级云端搜索体验(云原生搜索引擎)
android·前端·git·flutter·搜索引擎·云原生·harmonyos
王码码20358 小时前
Flutter 三方库 dns_client 的鸿蒙化适配指南 - 告别 DNS 劫持、探索 DNS-over-HTTPS (DoH) 技术、构建安全的鸿蒙网络请求环境
flutter·harmonyos·鸿蒙·openharmony·dns_client
键盘鼓手苏苏8 小时前
Flutter 组件 highlighter 适配鸿蒙 HarmonyOS 实战:高性能语法高亮,构建大规模代码分析与文本染色架构
flutter·harmonyos·鸿蒙·openharmony
国医中兴8 小时前
Flutter 三方库 langchain_google 的鸿蒙化适配指南 - 链接 Gemini 智慧中枢、LangChain AI 实战、鸿蒙级智能应用专家
flutter·langchain·harmonyos
左手厨刀右手茼蒿8 小时前
Flutter for OpenHarmony: Flutter 三方库 shamsi_date 助力鸿蒙应用精准适配波斯历法(中东出海必备)
android·flutter·ui·华为·自动化·harmonyos
雷帝木木8 小时前
Flutter 三方库 http_client_interceptor 的鸿蒙化适配指南 - 实现原生 HttpClient 的全量请求拦截、支持端侧动态 Headers 注入与网络流量审计实战
flutter·harmonyos·鸿蒙·openharmony·http_client_interceptor