应用程序崩溃:将应用程序升级到compileSdkVersion 33/ Android 13后请求权限

She*_*ani 10 dart android-permissions flutter

使用的包:permission_handler:^10.0.0

应用程序/build.Gradle

compileSdkVersion 33
minSdkVersion 24
targetSdkVersion 33

Run Code Online (Sandbox Code Playgroud)

android/build.gradle

kotlin_version = '1.7.10'
Run Code Online (Sandbox Code Playgroud)

AndroidManifest.xml中添加的权限

  <uses-permission
         android:name="android.permission.MANAGE_EXTERNAL_STORAGE"  tools:ignore="ScopedStorage" />
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
    <uses-permission android:name="android.permission.READ_INTERNAL_STORAGE" />
    <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
    <uses-permission android:name="android.permission.READ_MEDIA_IMAGES" />
    <uses-permission android:name="android.permission.READ_MEDIA_VIDEO" />
    <uses-permission android:name="android.permission.CAMERA" />
Run Code Online (Sandbox Code Playgroud)

单击允许或拒绝权限时崩溃日志


E/AndroidRuntime(13312): FATAL EXCEPTION: main
E/AndroidRuntime(13312): Process: com.app.example, PID: 13312
E/AndroidRuntime(13312): java.lang.AssertionError
E/AndroidRuntime(13312):    at io.flutter.plugins.firebase.messaging.FlutterFirebasePermissionManager.onRequestPermissionsResult(FlutterFirebasePermissionManager.java:33)
E/AndroidRuntime(13312):    at io.flutter.embedding.engine.FlutterEngineConnectionRegistry$FlutterEngineActivityPluginBinding.onRequestPermissionsResult(FlutterEngineConnectionRegistry.java:777)
E/AndroidRuntime(13312):    at io.flutter.embedding.engine.FlutterEngineConnectionRegistry.onRequestPermissionsResult(FlutterEngineConnectionRegistry.java:409)
E/AndroidRuntime(13312):    at io.flutter.embedding.android.FlutterActivityAndFragmentDelegate.onRequestPermissionsResult(FlutterActivityAndFragmentDelegate.java:757)
E/AndroidRuntime(13312):    at io.flutter.embedding.android.FlutterFragment.onRequestPermissionsResult(FlutterFragment.java:915)
E/AndroidRuntime(13312):    at io.flutter.embedding.android.FlutterFragmentActivity.onRequestPermissionsResult(FlutterFragmentActivity.java:549)
E/AndroidRuntime(13312):    at android.app.Activity.dispatchRequestPermissionsResult(Activity.java:8833)
E/AndroidRuntime(13312):    at android.app.Activity.dispatchActivityResult(Activity.java:8663)
E/AndroidRuntime(13312):    at android.app.ActivityThread.deliverResults(ActivityThread.java:5857)
E/AndroidRuntime(13312):    at android.app.ActivityThread.handleSendResult(ActivityThread.java:5903)
E/AndroidRuntime(13312):    at android.app.servertransaction.ActivityResultItem.execute(ActivityResultItem.java:54)
E/AndroidRuntime(13312):    at android.app.servertransaction.ActivityTransactionItem.execute(ActivityTransactionItem.java:45)
E/AndroidRuntime(13312):    at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:135)
E/AndroidRuntime(13312):    at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:95)
E/AndroidRuntime(13312):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2438)
E/AndroidRuntime(13312):    at android.os.Handler.dispatchMessage(Handler.java:106)
E/AndroidRuntime(13312):    at android.os.Looper.loopOnce(Looper.java:226)
E/AndroidRuntime(13312):    at android.os.Looper.loop(Looper.java:313)
E/AndroidRuntime(13312):    at android.app.ActivityThread.main(ActivityThread.java:8663)
E/AndroidRuntime(13312):    at java.lang.reflect.Method.invoke(Native Method)
E/AndroidRuntime(13312):    at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:571)
E/AndroidRuntime(13312):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1135)
I/Process (13312): Sending signal. PID: 13312 SIG: 9

Run Code Online (Sandbox Code Playgroud)

权限请求代码

compileSdkVersion 33
minSdkVersion 24
targetSdkVersion 33

Run Code Online (Sandbox Code Playgroud)

She*_*ani 5

此问题是由于 firebase_messaging: 13.0.0 引起的

升级与 firebase 相关的所有软件包将解决此权限崩溃问题。

在此输入图像描述


  firebase_core: ^1.22.0
  firebase_auth: ^3.8.0
  firebase_messaging: ^13.0.1
  firebase_dynamic_links: ^4.3.7

Run Code Online (Sandbox Code Playgroud)

问题已在 Github 中关闭:

https://github.com/firebase/flutterfire/issues/9430 https://github.com/firebase/flutterfire/issues/9429