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 系统要求)
相关推荐
程序员老刘2 天前
跨平台开发地图 | 2026年6月
flutter·ai编程·客户端
悟空瞎说3 天前
Flutter 架构详解:新手必懂底层原理
flutter
SoaringHeart3 天前
Flutter最佳实践:IM聊天文字链接自动识别跳转
前端·flutter
恋猫de小郭3 天前
KMP / CMP 鸿蒙版本 Beta 发布,他有什么特别之处?
android·前端·flutter
风华圆舞4 天前
Flutter + 鸿蒙 Intents Kit:页面直达能力的完整接入方案
flutter·ui·华为·harmonyos
韩曙亮4 天前
【Flutter】Flutter 组件 ④ ( 组件渲染 的 三棵树理论 | Widget 树 → Element 树 → RenderObject 树 )
flutter·element·widget·renderobject
初级代码游戏4 天前
easy Photo Clean公测版:快速清理iPhone照片 邀请公测
ios·iphone
库奇噜啦呼4 天前
【iOS】RunLoop学习
学习·ios
黑科技iOS上架4 天前
iOS应用周末提交什么情况算卡审
经验分享·ios
恋猫de小郭4 天前
Android 17 正式版发布,全新 AI 和各种破坏性更新
android·前端·flutter