简而言之,当我从意图中选择徽标图像并存储URI时,我可以显示/加载图像。这甚至在我退出应用程序并再次启动时也能正常工作。 但是当我重新启动平板电脑时,我遇到了许可问题。
长版:
用户可以选择图像
if (Build.VERSION.SDK_INT < 19){
intent = new Intent();
intent.setAction(Intent.ACTION_GET_CONTENT);
intent.setType("image/*");
} else {
intent = new Intent(Intent.ACTION_OPEN_DOCUMENT);
intent.addCategory(Intent.CATEGORY_OPENABLE);
intent.setType("image/*");
}
然后,我将内容提供者URI存储到我的应用程序的数据库中,如下所示:
content://com.android.providers.media.documents/document/image%3A53
将图像加载到imageView
myLogo.setImageURI(Uri.parse(f.getLogo_uri()));
当我关闭应用程序并再次启动时,徽标已加载 - 一切正常。 但是当我重新启动平板电脑时,我收到了此消息
ImageView﹕ Unable to open content: content://com.android.providers.media.documents/document/image%3A53
java.lang.SecurityException: Permission Denial: opening provider
com.android.providers.media.MediaDocumentsProvider from ProcessRecord
{x y:clazz.stuff} (pid=blah, uid=blah) requires android.permission.MANAGE_DOCUMENTS
or android.permission.MANAGE_DOCUMENTS
但我的AndroidManifest.xml正在授予该权限
<uses-permission android:name="android.permission.MANAGE_DOCUMENTS"/>
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
感谢任何帮助,谢谢!
P.S。我在android kitkat 4.4.4
答案 0 :(得分:5)
首先,Uri
到ContentProvider
不需要持久。它们是立即消费的,未来可能不一定在任意时间工作。
其次,您无权在将来拥有使用有效Uri
的权利,尤其是Android 4.4上的存储访问框架(您的ACTION_OPEN_DOCUMENT
路径)。提供商可能会为您提供更持久的权限,但您必须为此调用takePersistableUriPermission()
。有关详情,请参阅the Storage Access Framework documentation的“持久权限”部分。
您的具体错误感觉就像上面提到的第二个问题。
但我的AndroidManifest.xml正在授予该权限
除非您使用固件的签名密钥签名,否则无法保留MANAGE_DOCUMENTS
权限,因为这是signature
权限。