Flutter权限申请

本文介绍了如何在Flutter应用中使用permission_handler库来管理Android和iOS的权限。首先在pubspec.yaml中引入库,然后更新Android的gradle.properties和build.gradle文件,以及iOS的Podfile和Info.plist。接着展示了如何申请单个和多个权限,以及在权限被拒绝时如何引导用户到系统设置页面。最后提供了一个请求录音和相机权限的示例。

一、引入permission_handler库

在pubspec.yaml文件中引入permission_handler库

  permission_handler: ^9.0.2

permission_handler库地址:https://pub.flutter-io.cn/packages/permission_handler

二、Android iOS中添加相应权限

Android

1、将以下内容添加到“gradle.properties”文件中:(针对androidX及以上的版本)

android.useAndroidX=true
android.enableJetifier=true

2、确保"android/app/build.gradle"的 compileSdkVersion到31:

android {
  compileSdkVersion 31
  ...
}

3、在“AndroidManifest.xml”添加本项目需要用到的权限:

	<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
	<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
ios

1、Podfile 文件添加如下内容:

post_install do |installer|
  installer.pods_project.targets.each do |target|
    target.build_configurations.each do |config|
      ... # Here are some configurations automatically generated by flutter

      # You can enable the permissions needed here. For example to enable camera
      # permission, just remove the `#` character in front so it looks like this:
      #
      # ## dart: PermissionGroup.camera
      # 'PERMISSION_CAMERA=1'
      #
      #  Preprocessor definitions can be found in: https://github.com/Baseflow/flutter-permission-handler/blob/master/permission_handler/ios/Classes/PermissionHandlerEnums.h
      config.build_settings['GCC_PREPROCESSOR_DEFINITIONS'] ||= [
        '$(inherited)',

        ## dart: PermissionGroup.calendar
        # 'PERMISSION_EVENTS=1',

        ## dart: PermissionGroup.reminders
        # 'PERMISSION_REMINDERS=1',

        ## dart: PermissionGroup.contacts
        # 'PERMISSION_CONTACTS=1',

        ## dart: PermissionGroup.camera
        # 'PERMISSION_CAMERA=1',

        ## dart: PermissionGroup.microphone
        # 'PERMISSION_MICROPHONE=1',

        ## dart: PermissionGroup.speech
        # 'PERMISSION_SPEECH_RECOGNIZER=1',

        ## dart: PermissionGroup.photos
        # 'PERMISSION_PHOTOS=1',

        ## dart: [PermissionGroup.location, PermissionGroup.locationAlways, PermissionGroup.locationWhenInUse]
        # 'PERMISSION_LOCATION=1',

        ## dart: PermissionGroup.notification
        # 'PERMISSION_NOTIFICATIONS=1',

        ## dart: PermissionGroup.mediaLibrary
        # 'PERMISSION_MEDIA_LIBRARY=1',

        ## dart: PermissionGroup.sensors
        # 'PERMISSION_SENSORS=1',   

        ## dart: PermissionGroup.bluetooth
        # 'PERMISSION_BLUETOOTH=1',

        ## dart: PermissionGroup.appTrackingTransparency
        # 'PERMISSION_APP_TRACKING_TRANSPARENCY=1',

        ## dart: PermissionGroup.criticalAlerts
        # 'PERMISSION_CRITICAL_ALERTS=1'
      ]

    end
  end
end

2、删除要使用的权限前面的字符。例如,如果您需要访问相册,请确保代码如下所示:

## dart: PermissionGroup.photos
        'PERMISSION_PHOTOS=1',

3、Info.plist 添加

<!-- 保存图片权限 -->
<key>NSPhotoLibraryAddUsageDescription</key>
<string>Please allow the APP to save photos to the album</string>

4、Clean & Rebuild

三、申请权限

1、申请单个权限:

var status = await Permission.camera.status;
if (status.isDenied) {
  // We didn't ask for permission yet or the permission has been denied before but not permanently.
}

// You can can also directly ask the permission about its status.
if (await Permission.location.isRestricted) {
  // The OS restricts access, for example because of parental controls.
}

2、申请多个权限:

if (await Permission.contacts.request().isGranted) {
  // Either the permission was already granted before or the user just granted it.
}

// You can request multiple permissions at once.
Map<Permission, PermissionStatus> statuses = await [
  Permission.location,
  Permission.storage,
].request();
print(statuses[Permission.location]);

3、granted 通过,denied 被拒绝,permanentlyDenied 拒绝且不在提示,权限被拒绝时,跳转手机设置页面让用户自行开启权限

 openAppSettings();

调用前需要先导包

import 'package:permission_handler/permission_handler.dart';

四、示例

  ///请求录音相机权限
  Future<bool> getMicrophonePermission() async {
    // You can request multiple permissions at once.
    Map<Permission, PermissionStatus> statuses = await [
      Permission.microphone,
      Permission.camera,
    ].request();

    //granted 通过,denied 被拒绝,permanentlyDenied 拒绝且不在提示
    if (statuses[Permission.microphone].isGranted &&
        statuses[Permission.camera].isGranted) {
      return true;
    }
    return false;
  }
getMicrophonePermission()
            .then((value) {
                if (value) {有权限
                                  
                }else{//没有权限
                
                 openAppSettings();//打开app系统设置
                                }
                              });
Flutter申请通知权限,可参考通用的权限申请思路。对于权限申请,较好的做法是先执行相关操作,让系统弹出权限弹框,而不是先调用`.request()` 。比如在处理拍照权限时,直接调用拍照的API,系统会弹出权限弹框;同理,申请通知权限时,可直接尝试执行需要通知权限的操作,促使系统弹出权限申请框[^1]。 在iOS系统中,首次申请权限时,如果用户选择了“拒绝”,权限状态将变为`isPermanentlyDenied`,之后无法再调用`request()`来取得权限,必须去应用设置界面手动开启权限,可使用`openAppSettings()`跳转到应用设置界面 [^2]。 权限状态有以下几种:`isGranted`(已授权)、`isDenied`(被拒绝)、`isPermanentlyDenied`(被永久拒绝,需要去设置页开启)、`isRestricted`(受限制,仅iOS),在申请通知权限时,需要根据这些不同的权限状态进行相应处理 [^3]。 以下是一个简单的示例代码展示如何申请权限(此处以通用权限申请思路展示,通知权限申请同理): ```dart import 'package:flutter/material.dart'; import 'package:permission_handler/permission_handler.dart'; class PermissionExample extends StatefulWidget { @override _PermissionExampleState createState() => _PermissionExampleState(); } class _PermissionExampleState extends State<PermissionExample> { Future<void> _requestPermission() async { // 这里以申请通知权限为例,可替换为实际权限 PermissionStatus status = await Permission.notification.request(); if (status.isGranted) { print('权限已授予'); } else if (status.isDenied) { print('权限被拒绝'); } else if (status.isPermanentlyDenied) { print('权限被永久拒绝,需要去设置页开启'); await openAppSettings(); } else if (status.isRestricted) { print('权限受限制(仅iOS)'); } } @override Widget build(BuildContext context) { return Scaffold( appBar: AppBar( title: Text('权限申请示例'), ), body: Center( child: ElevatedButton( onPressed: _requestPermission, child: Text('申请通知权限'), ), ), ); } } ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值