从图库加载图像时罕见的安全例外

时间:2018-06-08 07:58:19

标签: android permissions android-gallery

我一直在浏览Google Play控制台中列出的崩溃问题。我无法重现的一次崩溃:

java.lang.RuntimeException: 
at android.app.ActivityThread.deliverResults (ActivityThread.java:3778)
at android.app.ActivityThread.handleSendResult (ActivityThread.java:3821)
at android.app.ActivityThread.access$1400 (ActivityThread.java:168)
at android.app.ActivityThread$H.handleMessage (ActivityThread.java:1428)
at android.os.Handler.dispatchMessage (Handler.java:102)
at android.os.Looper.loop (Looper.java:150)
at android.app.ActivityThread.main (ActivityThread.java:5659)
at java.lang.reflect.Method.invoke (Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run (ZygoteInit.java:822)
at com.android.internal.os.ZygoteInit.main (ZygoteInit.java:712)
    Caused by: java.lang.SecurityException: 
at android.os.Parcel.readException (Parcel.java:1602)
at android.database.DatabaseUtils.readExceptionFromParcel (DatabaseUtils.java:183)
at android.database.DatabaseUtils.readExceptionFromParcel (DatabaseUtils.java:135)
at android.content.ContentProviderProxy.query (ContentProviderNative.java:421)
at android.content.ContentResolver.query (ContentResolver.java:513)
at android.content.ContentResolver.query (ContentResolver.java:438)
at za.co.overtake.onlinetrucks.utils.Utils.getBitmapFromUri (Utils.java:381)
at za.co.overtake.onlinetrucks.fragments.DamagePanelDetailsDialogFragment.onActivityResult (DamagePanelDetailsDialogFragment.java:513)
at android.support.v4.app.FragmentActivity.onActivityResult (FragmentActivity.java:164)
at android.app.Activity.dispatchActivityResult (Activity.java:6602)
at android.app.ActivityThread.deliverResults (ActivityThread.java:3774)

据报道,这起事故发生在Hauwei P8 Lite上。我已经在各种设备(包括Hauwei P8)上进行了测试,但无法重现这个问题!这些是我的清单文件中的权限:

<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.CAMERA" />
<uses-permission android:name="android.permission.RECORD_AUDIO" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />

在这里我请求用户权限:

public static void dispatchLoadGalleryEvent(Context context, Fragment frag) {
    if (PackageManager.PERMISSION_GRANTED != ActivityCompat.checkSelfPermission(context,
            Manifest.permission.WRITE_EXTERNAL_STORAGE)) {
        PermissionUtil.requestWritePermission(context, frag, ACCESS_GALLERY_PERMISSION_CODE);
        return;
    }

    Intent i = new Intent(
            Intent.ACTION_PICK,
            android.provider.MediaStore.Images.Media.EXTERNAL_CONTENT_URI);

    frag.startActivityForResult(i, ACCESS_GALLERY_REQUEST_CODE);
}

然后在这里我使用从intent返回的URI加载Image:

 public static Bitmap getBitmapFromUri(Context context, Uri selectedImage) {
    String[] filePathColumn = { MediaStore.Images.Media.DATA };
    Cursor cursor = context.getContentResolver().query(selectedImage, filePathColumn,
            null, null, null);
    cursor.moveToFirst();
    int columnIndex = cursor.getColumnIndex(filePathColumn[0]);
    String picturePath = cursor.getString(columnIndex);
    cursor.close();
    return (Utils.getBitmapFromFileWithCorrectOrientation(picturePath, 4));
}

报告崩溃发生在context.getContentResolver()。query()行上。我觉得我在某个地方做某些愚蠢的事情,并且非常困惑我无法重现这个问题。

1 个答案:

答案 0 :(得分:0)

SecurityException

  

由安全管理器抛出以表示违反安全性。

Throwable.getMessage()将提供有关“安全性”的使用特定信息。没有消息,很难确定问题所在。

Caused by: java.lang.SecurityException: <We got getMessage() data here but it is blank>

该日志猫来自Google PlayStore。关于用户动作,它有很多可能性。如:-

1。。用户拒绝某些权限。

2。。用户想要在未经许可的情况下运行您的应用。

3。。我认为您必须处理所有权限验证。如果用户要拒绝权限,则必须停止用户查看该页面和功能或仅对其进行处理,以免用户拒绝任何权限时崩溃。

更多

仅在拒绝所有权限的情况下尝试运行您的应用,并尝试查看它是否正在运行,如果应用在任何地方崩溃,都可以找到合适的解决方案。

注意:-从开始到结束都是关于测试应用程序的事情。