我的应用程序允许用户从图库或其他位置查看一些选定的图像。我通过以下方式请求图像的 Uri:
Intent photoPickerIntent = new Intent(Intent.ACTION_PICK);
photoPickerIntent.setType("image/*");
startActivityForResult(photoPickerIntent, PickerFragment.PICK_PHOTO);
然后在 onActivityResult (int requestCode, int resultCode, Intent data) 中获取 Uri,并通过以下方式访问这些图像以将它们放入我的应用程序的视图中:
Uri imageUri= data.getData();
应用程序完成后,我将数据库中的所有 Uri 保存为字符串:
String imageUriString = imageUri.toString();
saveToDB (imageUriString);
但是,当我重新启动应用程序并通过以下方式从我的数据库恢复所有 Uri 时:
String imageUriString = restoreFromDB ();
imageUri = Uri.parse (imageUriString);
在 Android 7.1 中,该应用程序不再具有这些 Uri 的权限。 我通过以下方式访问图像:
ContentResolver cr = mContext.getContentResolver();
InputStream is = cr.openInputStream(imageUri);
BitmapFactory.decodeStream(is, null, o);
但收到此异常:
java.lang.SecurityException: Permission Denial: opening provider com.google.android.apps.photos.contentprovider.impl.MediaContentProvider from ProcessRecord
是否有一种优雅且合法的方式来保留该许可? 我尝试阅读所有有关权限的文档,但感到非常困惑。
如果您能给我正确的学习方向,我将不胜感激。
PS 在 Uri 的许可持续期间将图像复制到应用程序内存中是一种选择,但我想避免这种情况。至少看看是否可能。
PPS 我拥有授予的所有权限,例如相机和外部存储写入和读取。
因此,在@greenapps的大力帮助下,在模拟器和真实设备上进行测试后,解决方案是这样的:
使用另一个意图:
Intent photoPickerIntent = new Intent(Intent.ACTION_OPEN_DOCUMENT);
在 onActivityResult() 中确保 Uri 的持久权限,该权限在应用程序重新启动后将保持不变:
Uri selectedImage = data.getData();
if (Build.VERSION.SDK_INT > Build.VERSION_CODES.JELLY_BEAN_MR2) {
getContentResolver().takePersistableUriPermission (selectedImage, Intent.FLAG_GRANT_READ_URI_PERMISSION|Intent.FLAG_GRANT_WRITE_URI_PERMISSION);
}