在应用程序中,用户使用ACTION_OPEN_DOCUMENT_TREE意图通过 SAF 选择一个目录,并且用户可以在其中创建各种文件。问题是当用户更改工作目录(始终使用 SAF)时,对这些文件的访问权限就会丢失。ACTION_CREATE_DOCUMENT如何保持或 之类的访问权限ACTION_OPEN_DOCUMENT?
这是我的代码
private void showDirectoryPicker() {
Intent i = new Intent(Intent.ACTION_OPEN_DOCUMENT_TREE)
i.addFlags(Intent.FLAG_GRANT_PERSISTABLE_URI_PERMISSION);
i.addFlags(Intent.FLAG_GRANT_READ_URI_PERMISSION | Intent.FLAG_GRANT_WRITE_URI_PERMISSION);
startActivityForResult(i, 12345);
}
Run Code Online (Sandbox Code Playgroud)
public void onActivityResult(int requestCode, int resultCode, Intent data) {
if (resultCode != Activity.RESULT_OK) return;
mDir = data.getData();
grantUriPermission(getPackageName(), mDir, Intent.FLAG_GRANT_READ_URI_PERMISSION | Intent.FLAG_GRANT_WRITE_URI_PERMISSION);
getContentResolver().takePersistableUriPermission(mDir, Intent.FLAG_GRANT_READ_URI_PERMISSION | Intent.FLAG_GRANT_WRITE_URI_PERMISSION);
}
Run Code Online (Sandbox Code Playgroud)
mFile = DocumentFile.fromTreeUri(getContext(), mDir).createFile("text/plain", "some file.txt").getUri();
Run Code Online (Sandbox Code Playgroud)
getContentResolver().releasePersistableUriPermission(mDir, Intent.FLAG_GRANT_READ_URI_PERMISSION | Intent.FLAG_GRANT_WRITE_URI_PERMISSION);
revokeUriPermission(mDir, Intent.FLAG_GRANT_READ_URI_PERMISSION | Intent.FLAG_GRANT_WRITE_URI_PERMISSION);
mDir = null;
// ask for another dir
showDirectoryPicker();
Run Code Online (Sandbox Code Playgroud)
一旦我重新启动应用程序并尝试打开在旧目录中创建的文件,我得到:
java.lang.SecurityException: No persistable permission grants found for UID <<<uid>>> and Uri 0 @ <<<file uri>>>
例子:
DocumentFile file = DocumentFile.fromSingleUri(getContext(), mFile);
if (file.getName() == null) {
// permissions lost
} else {
// do something
}
Run Code Online (Sandbox Code Playgroud)
怎么处理这个?或者只保留目录权限直到应用程序被卸载???
简单的解决方案是在完成该树中的所有内容之前不要释放权限授予。用户更改他们将用于未来操作的树不会改变您使用他们想要用于过去操作的树的需要,至少对于您仍然保留Uri值的那些内容片段而言。
您可以尝试请求Uri对旧树中各个内容的单独授予,然后释放对旧树的权限授予。我从来没有尝试过这个,所以我不知道它是否有效。这是我能想到的最优雅的许可解决方案,因为您所拥有的权限不会超过您实际需要的权限。
| 归档时间: |
|
| 查看次数: |
1500 次 |
| 最近记录: |