Flutter iOS 权限配置完整指南(定位权限)

一、核心配置(你需要的完整代码)

1. 找到配置文件

路径:ios/Podfile

2. 替换 / 添加这段代码

找到 post_install 代码块,替换成以下完整配置:

ruby

复制代码
post_install do |installer|
  installer.pods_project.targets.each do |target|
    flutter_additional_ios_build_settings(target)
    
    # 定位权限配置(你需要的核心代码)
    target.build_configurations.each do |config|
      # 仅使用时定位权限
      config.build_settings['GCC_PREPROCESSOR_DEFINITIONS'] ||= ['$(inherited)']
      config.build_settings['GCC_PREPROCESSOR_DEFINITIONS'] << 'PERMISSION_LOCATION_WHEN_IN_USE=1'
      # 始终允许定位权限
      config.build_settings['GCC_PREPROCESSOR_DEFINITIONS'] << 'PERMISSION_LOCATION_ALWAYS=1'
    end
  end
end

二、必须补充的 iOS 权限声明(不配置会崩溃 / 被拒)

仅配置宏不够,必须在 Info.plist 添加权限描述文案,否则 App 无法请求定位、审核被拒。

1. 打开文件

路径:ios/Runner/Info.plist

2. 添加以下代码

xml

复制代码
<key>NSLocationWhenInUseUsageDescription</key>
<string>需要获取您的位置信息,用于展示当前位置、导航等功能</string>
<key>NSLocationAlwaysAndWhenInUseUsageDescription</key>
<string>需要始终获取您的位置信息,用于后台定位、轨迹记录等功能</string>
<key>NSLocationAlwaysUsageDescription</key>
<string>需要始终获取您的位置信息</string>

文案可以根据你的业务修改,不能为空


三、生效步骤

配置完成后,执行以下命令让配置生效:

  1. 进入 iOS 目录:cd ios
  2. 重新安装依赖:pod install
  3. 返回根目录:cd ..
  4. 重启 Flutter 项目

四、代码解释

  1. GCC_PREPROCESSOR_DEFINITIONS:iOS 编译预定义宏
  2. PERMISSION_LOCATION_WHEN_IN_USE=1:开启仅使用时定位权限
  3. PERMISSION_LOCATION_ALWAYS=1:开启始终定位权限
  4. ||= ['$(inherited)']关键修复 ------ 防止覆盖原有配置,避免编译报错

五、常见问题

1. 报错:Undefined symbol

原因:缺少 ||= ['$(inherited)'],用我给的完整代码即可解决。

2. 权限请求不弹出

原因:未配置 Info.plist 权限文案,必须补充。

3. 只需要一种定位权限

  • 仅使用时:只保留 PERMISSION_LOCATION_WHEN_IN_USE=1
  • 始终允许:必须同时保留两个宏(iOS 系统要求)
相关推荐
A_QXBlms2 小时前
多账号轮询架构 — 利用企销宝iPad协议突破单账号群发次数限制
ios·架构·ipad
早點睡3902 小时前
Flutter for OpenHarmony三方库适配实战:flutter_local_notifications 本地通知
flutter
哈__2 小时前
Flutter for OpenHarmony三方库适配实战:flutter_tts 文字转语音
flutter
木子雨廷2 小时前
Flutter Redux 项目实战
flutter
AI_零食2 小时前
Flutter 框架跨平台鸿蒙开发 - 颜色听觉化应用
学习·flutter·信息可视化·开源·harmonyos
2301_822703202 小时前
大学生体质健康测试全景测绘台:基于鸿蒙Flutter的多维数据可视化与状态管理响应架构
算法·flutter·信息可视化·架构·开源·harmonyos·鸿蒙
独特的螺狮粉2 小时前
生命科学实验室经费极简记账簿:基于鸿蒙Flutter的极简主义状态响应与流式布局架构
flutter·华为·架构·开源·harmonyos
HH思️️无邪2 小时前
Flutter + iOS 实战指南:教程视频 PiP + 退桌面(可复用模板)
flutter·ios
提子拌饭1332 小时前
红细胞代偿性增殖与睡眠剥夺的对照演算引擎:基于鸿蒙Flutter的微观流体力学粒子渲染架构
flutter·华为·架构·开源·harmonyos·鸿蒙