安卓 API 33 权限未被授权。

19
根据我在developer.android网站上的阅读,Android 13在权限领域带来了新的变化。我有一个聊天应用程序,需要拨打电话、打开相机、录制音频、读写外部存储。因此,在启动屏幕中,我向用户请求这些权限。但是,即使系统没有要求,其中一些权限也没有被授予。以下是我在AndroidManifest.xml文件中声明的内容。
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools">

    <uses-permission android:name="android.permission.READ_PHONE_STATE" />
    <uses-permission android:name="com.google.android.c2dm.permission.RECEIVE" />
    <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
    <uses-permission android:name="android.permission.RECORD_AUDIO" />
    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="android.permission.VIBRATE" />
    <uses-permission android:name="android.permission.USE_FULL_SCREEN_INTENT" />
    <uses-permission android:name="android.permission.CAMERA" />
    <uses-permission android:name="android.permission.CHANGE_NETWORK_STATE" />
    <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    <uses-permission android:name="android.permission.MODIFY_AUDIO_SETTINGS" />
    <uses-permission android:name="android.permission.BLUETOOTH" />
    <uses-permission android:name="android.permission.BLUETOOTH_ADMIN" />
    <uses-permission android:name="android.permission.BLUETOOTH_CONNECT" />
    <uses-permission android:name="android.permission.FOREGROUND_SERVICE" />
    <uses-permission android:name="android.permission.WAKE_LOCK" />
    <uses-permission android:name="com.google.android.gms.permission.AD_ID"/>
    <uses-permission android:name="android.permission.POST_NOTIFICATIONS"/>

    <uses-feature
        android:name="android.hardware.camera"
        android:required="true" />
    <uses-feature android:name="android.hardware.camera.autofocus" />
    <uses-feature
        android:glEsVersion="0x00020000"
        android:required="true" />

    <application
        android:name=".ChatApplication"
        android:allowBackup="false"
        android:dataExtractionRules="@xml/data_extraction_rules"
        android:fullBackupContent="false"
        android:hardwareAccelerated="true"
        android:icon="@mipmap/logo"
        android:label="@string/app_name"
        android:largeHeap="true"
        android:networkSecurityConfig="@xml/network_security_config"
        android:requestLegacyExternalStorage="true"
        android:roundIcon="@mipmap/logo"
        android:supportsRtl="true"
        android:theme="@style/AppTheme"
        tools:ignore="AllowBackup,GoogleAppIndexingWarning,UnusedAttribute"
        tools:replace="android:allowBackup, android:label">

这是启动屏幕活动中的代码:

class SplashActivity : BaseActivity() {

    private val splashViewModel: SplashViewModel by viewModels()

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_splash)

        if (!hasPermissions(this, *REQUIRED_PERMISSIONS))
            ActivityCompat.requestPermissions(this, REQUIRED_PERMISSIONS, ALL_PERMISSIONS)
        else
            Handler(Looper.getMainLooper()).postDelayed ({ startUi() }, 1000)
    }

    private fun hasPermissions(context: Context, vararg permissions: String): Boolean =
        permissions.all {
            ActivityCompat.checkSelfPermission(context, it) == PackageManager.PERMISSION_GRANTED
        }

    private fun startUi() {
        // navigate to main application
    }

    private fun finishActivity() {
        toast("You must grant all required permissions to continue")
        finish()
    }

    override fun onRequestPermissionsResult(
        requestCode: Int,
        permissions: Array<out String>,
        grantResults: IntArray
    ) {
        super.onRequestPermissionsResult(requestCode, permissions, grantResults)
        when (requestCode) {
            ALL_PERMISSIONS -> {
                if (grantResults.all { it == PackageManager.PERMISSION_GRANTED }) startUi()
                else finishActivity()
            }
        }
    }

    companion object {
        const val ALL_PERMISSIONS = 10
        private val REQUIRED_PERMISSIONS =
            mutableListOf (
                Manifest.permission.READ_PHONE_STATE,
                Manifest.permission.RECORD_AUDIO,
                Manifest.permission.CAMERA
            ).apply {
                if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.TIRAMISU) {
                    add(Manifest.permission.READ_MEDIA_IMAGES)
                    add(Manifest.permission.READ_MEDIA_VIDEO)
                    add(Manifest.permission.READ_MEDIA_AUDIO)
                    add(Manifest.permission.POST_NOTIFICATIONS)
                } else if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.Q)
                    add(Manifest.permission.WRITE_EXTERNAL_STORAGE)
            }.toTypedArray()
    }
}

当我在onRequestPermissionsResult中设置断点时,我看到了这个enter image description here

我在屏幕上看到的权限提示是相机、录制音频和电话状态。在这些权限之后,应用程序通过调用finishActivity()退出。

我正在一个Pixel 6 Pro API 33模拟器中运行应用程序。如何正确进行操作?我该如何解决这个问题?

6个回答

31
在Android 13中,你不需要请求权限。
这是一个示例代码,用于传递权限。
在Mainfests.xml中添加。
<uses-permission android:name="android.permission.READ_MEDIA_IMAGES" />
<uses-permission android:name="android.permission.READ_MEDIA_AUDIO" />
<uses-permission android:name="android.permission.READ_MEDIA_VIDEO" />

<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"
      tools:ignore="ScopedStorage" />

然后,在你的课堂或活动中添加:

public static String[] storage_permissions = {
        Manifest.permission.WRITE_EXTERNAL_STORAGE,
        Manifest.permission.READ_EXTERNAL_STORAGE
};

@RequiresApi(api = Build.VERSION_CODES.TIRAMISU)
public static String[] storage_permissions_33 = {
        Manifest.permission.READ_MEDIA_IMAGES,
        Manifest.permission.READ_MEDIA_AUDIO,
        Manifest.permission.READ_MEDIA_VIDEO
};

public static String[] permissions() {
    String[] p;
    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.TIRAMISU) {
        p = storage_permissions_33;
    } else {
        p = storage_permissions;
    }
    return p;
}

在请求权限时,调用permissions()函数;
 ActivityCompat.requestPermissions(MainActivity.this, 
                              permissions(), 
                              1);

谢谢分享。看起来不错,我会试一试。 - undefined

14

根据日志,你可能缺少3个权限,它们分别是

 - READ_MEDIA_IMAGES
 - READ_MEDIA_VIDEO
 - READ_MEDIA_AUDIO

在清单文件中添加代替上述3个权限

 <uses-permission android:name="android.permission.READ_MEDIA_*"/>

为了获取以上三个权限,只需要获取外部存储权限。 在下面的链接中,Android文档仅提供以下三个权限:
READ_MEDIA_IMAGES,
READ_MEDIA_VIDEO,
READ_MEDIA_AUDIO,而不是使用READ_EXTERNAL_STORAGE
链接:https://developer.android.com/about/versions/13/behavior-changes-13#granular-media-permissions


请问能否帮我,我已经按照您所提到的所有权限进行设置,但仍然出现相同的错误。 - MARSH
1
谢谢,它已经起作用了,是我的错误,我没有添加条件。 - MARSH

3
对于Android 13,在清单文件中添加以下内容
<uses-permission android:name="android.permission.READ_MEDIA_IMAGES" />
<uses-permission android:name="android.permission.READ_MEDIA_VIDEO" />
<uses-permission android:name="android.permission.READ_MEDIA_AUDIO" />

在 Kotlin 代码中:
private val PERMISSIONS =
    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.TIRAMISU) {
        arrayOf(
            Manifest.permission.READ_MEDIA_IMAGES,
            Manifest.permission.READ_MEDIA_VIDEO,
            Manifest.permission.READ_MEDIA_AUDIO
        )
    } else {
        arrayOf(
            Manifest.permission.READ_EXTERNAL_STORAGE,
            Manifest.permission.WRITE_EXTERNAL_STORAGE,
            Manifest.permission.CAMERA
        )
    }

    if (!HandleAndroidPermissions.hasPermissions(context, *PERMISSIONS)) {
        ActivityCompat.requestPermissions(
             requireActivity(),
             PERMISSIONS,
             101
        );
    } else {
        captureImage()
    }

1
我找不到适合我的情况的解决方案。我想要在Android 13及以下版本中获得从图库获取图片的权限。
这是我想出来的方法:
我的清单文件在13版本中(最低需要在10版本中使用该应用程序):
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.READ_MEDIA_IMAGES" />
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"
    android:maxSdkVersion="32" />

在CONTAININGActivity的主类中,在onCreate方法之前添加:

    private static final int REQUEST_CODE_STORAGE_PERMISSION = 1;

在Class/Activity中添加,在onCreate方法之外:
 private static final String readExternalStorage;

    private static final String readMediaImages;

    public static String storage_permissions = readExternalStorage = Manifest.permission.READ_EXTERNAL_STORAGE;

    @RequiresApi(api = Build.VERSION_CODES.TIRAMISU)
    public static String storage_permissions_33 = readMediaImages = Manifest.permission.READ_MEDIA_IMAGES;

    public static String[] permissions() {
        String p;
        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.TIRAMISU) {
            p = storage_permissions_33;
        } else {
            p = storage_permissions;
        }
        return new String[]{p};
    }

我在ActivityCompat中使用了这个来获取权限。
ActivityCompat.requestPermissions(
                            CONTAININGActivity.this,
                            permissions(),
                            REQUEST_CODE_STORAGE_PERMISSION
                    );

0

在Android 13中,只有三个权限READ_MEDIA_IMAGES、READ_MEDIA_VIDEO和READ_MEDIA_AUDIO。我该如何请求PDF的权限呢?


如果你有一个新问题,请通过点击Ask Question按钮来提问。如果需要提供上下文,请包括这个问题的链接。- [来自审阅] (/review/late-answers/34470202) - Sergei Kozelko

0
 private val mPermissions = if(Build.VERSION.SDK_INT >=33 ){
        arrayOf (
            Manifest.permission.READ_MEDIA_AUDIO,
            Manifest.permission.READ_MEDIA_IMAGES)
    }else{
        arrayOf (
            Manifest.permission.WRITE_EXTERNAL_STORAGE,
            Manifest.permission.READ_EXTERNAL_STORAGE
        )
    }

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接