Подтвердить что ты не робот

Strange ArrayIndexOutOfBoundsException в android.support.v4.app.ActivityCompat.OnRequestPermissionsResultCallback

Я получил странное исключение из-за ограничений в консоли Play Store, относящееся к android.support.v4.app.ActivityCompat.OnRequestPermissionsResultCallback

java.lang.ArrayIndexOutOfBoundsException: length=0; index=0
    at com.example.MyFragmentActivity.onRequestPermissionsResult(MyFragmentActivity.java:2068)
    at android.app.Activity.requestPermissions(Activity.java:4163)
    at android.support.v4.app.ActivityCompatApi23.requestPermissions(ActivityCompat23.java:32)
    at android.support.v4.app.ActivityCompat.requestPermissions(ActivityCompat.java:316)
    at com.example.MyFragmentActivity.onConnected(MyFragmentActivity.java:2048)
    at com.google.android.gms.common.internal.zzk.zzk(Unknown Source)
    at com.google.android.gms.common.api.internal.zzj.zzi(Unknown Source)
    at com.google.android.gms.common.api.internal.zzh.zzpx(Unknown Source)
    at com.google.android.gms.common.api.internal.zzh.onConnected(Unknown Source)
    at com.google.android.gms.common.api.internal.zzl.onConnected(Unknown Source)
    at com.google.android.gms.common.api.internal.zzc.onConnected(Unknown Source)
    at com.google.android.gms.common.internal.zzj$zzg.zzqL(Unknown Source)
    at com.google.android.gms.common.internal.zzj$zza.zzc(Unknown Source)
    at com.google.android.gms.common.internal.zzj$zza.zzw(Unknown Source)
    at com.google.android.gms.common.internal.zzj$zzc.zzqN(Unknown Source)
    at com.google.android.gms.common.internal.zzj$zzb.handleMessage(Unknown Source)
    at android.os.Handler.dispatchMessage(Handler.java:102)
    at android.os.Looper.loop(Looper.java:158)
    at android.app.ActivityThread.main(ActivityThread.java:7229)
    at java.lang.reflect.Method.invoke(Native Method)
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1230)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1120)

Это моя реализация onRequestPermissionsResult

@Override
public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults) {
    switch (requestCode) {
        case REQUEST_CODE_ASK_LOCATION_PERMISSIONS:
            if (grantResults[0] == PackageManager.PERMISSION_GRANTED) {
                // Permission Granted
                if (ContextCompat.checkSelfPermission(this, Manifest.permission.ACCESS_FINE_LOCATION) == PackageManager.PERMISSION_GRANTED) {
                    mLastLocation = LocationServices.FusedLocationApi.getLastLocation(mGoogleApiClient);
                }
                startLocationUpdates();
            } else {
                // Permission Denied
            }
            break;
        default:
            super.onRequestPermissionsResult(requestCode, permissions, grantResults);
    }
}

Строка 2068 такова:

if (grantResults[0] == PackageManager.PERMISSION_GRANTED) {

Я считаю, что утверждение grantResults length равно нулю, поэтому генерируется исключение java.lang.ArrayIndexOutOfBoundsException. Согласно документации

int: результаты предоставления для соответствующих разрешений, которые либо PERMISSION_GRANTED или PERMISSION_DENIED. Никогда не имеет значения.

grantResults не будет null, но ничего не говорит об этом, не содержащем значения. Кроме того, похоже, что обратный вызов будет содержать хотя бы одно значение: PERMISSION_GRANTED или PERMISSION_DENIED. Является ли это ошибкой или я не понимаю документацию?

4b9b3361

Ответ 1

Документация о разрешениях сообщает

Если запрос отменен, массивы результатов пустые.

И это, кажется, ваша ситуация, поэтому сначала нужно проверить, не массив ли массив:

@Override
public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults) {
    switch (requestCode) {
        case REQUEST_CODE_ASK_LOCATION_PERMISSIONS:
            if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) {
                // Permission Granted
                if (ContextCompat.checkSelfPermission(this, Manifest.permission.ACCESS_FINE_LOCATION) == PackageManager.PERMISSION_GRANTED) {
                    mLastLocation = LocationServices.FusedLocationApi.getLastLocation(mGoogleApiClient);
                }
                startLocationUpdates();
            } else {
                // Permission Denied
            }
            break;
        default:
            super.onRequestPermissionsResult(requestCode, permissions, grantResults);
    }
}

Ответ 2

Код Kotlin для проверки разрешения и исправления этой ошибки: лучше проверить размер IntArray с помощью .isNotEmpty() в Kotlin.

 override fun onRequestPermissionsResult(
    requestCode: Int, permissions: Array<out String>,
    grantResults: IntArray
) {
    when (requestCode) {
        PERMISSIONS_REQUEST_PICK_IMAGE_GALLERY -> {
            if (grantResults.isNotEmpty()  &&  grantResults[0] == PackageManager.PERMISSION_GRANTED) {
                choosePhotoFromGallary()
            } else  //Permission Denied
                //  toast("Permission must be granted in order to...")
        }
        PERMISSIONS_REQUEST_TAKE_PICTURE_CAMERA -> {
            if (grantResults.isNotEmpty() && grantResults[0] == PackageManager.PERMISSION_GRANTED) {
                takePhotoFromCamera()
            } else  //Permission Denied
                //  toast("Permission must be granted in order to ...")
        }
    } // when
} // fun