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 系统要求)
相关推荐
harder3213 小时前
RMP模式的创新突破
开发语言·学习·ios·swift·策略模式
maaath4 小时前
【maaath】Flutter for OpenHarmony 跨平台工程集成密码加密能力
flutter·华为·harmonyos
yeziyfx4 小时前
Flutter 纯色矩形
flutter
liulian09165 小时前
Flutter for OpenHarmony 混合开发实践:用户反馈功能的实现与适配
flutter·华为·学习方法·harmonyos
Hello__77776 小时前
开源鸿蒙 Flutter 实战|文章分类标签功能全流程实现
flutter·开源·harmonyos
xiaoyan20157 小时前
2026爆肝!Flutter3.41纯手撸微信聊天APP原生应用
android·flutter·dart
程序员老刘7 小时前
当全网都在喊“程序员要被AI取代了”,Flutter给了另一种答案
flutter·ai编程·客户端
国医中兴7 小时前
Flutter 三方库 nhost_graphql_adapter 的鸿蒙化适配指南 - 云端数据实时对齐、GraphQL 架构实战、鸿蒙级全栈交互专家
flutter·harmonyos·graphql
for_ever_love__8 小时前
UI学习:UITableView的基本操作及折叠cell
学习·ui·ios
IntMainJhy10 小时前
Flutter 三方库 get_it + flutter_bloc 的鸿蒙化适配与实战指南
flutter·华为·harmonyos