Я пытаюсь протестировать Storage Access Framework в примере Activity.Цель состоит в том, чтобы получить постоянное разрешение на чтение / запись для выбранной пользователем папки.
Вот как приложение запускает средство выбора SAF-файла:
Intent intent = new Intent(Intent.ACTION_OPEN_DOCUMENT_TREE);
intent.addFlags(Intent.FLAG_GRANT_PERSISTABLE_URI_PERMISSION);
intent.addFlags(Intent.FLAG_GRANT_READ_URI_PERMISSION);
intent.addFlags(Intent.FLAG_GRANT_WRITE_URI_PERMISSION);
startActivityForResult(intent, OPEN_DIRECTORY_REQUEST_CODE);
вызывается метод onActivityResult:
@Override
protected void onActivityResult(int requestCode,int resultCode, Intent data)
{
super.onActivityResult(requestCode, resultCode, data);
if (requestCode == OPEN_DIRECTORY_REQUEST_CODE)
{
if (resultCode == Activity.RESULT_OK)
{
int takeFlags = data.getFlags()& (Intent.FLAG_GRANT_READ_URI_PERMISSION
| Intent.FLAG_GRANT_WRITE_URI_PERMISSION);
ContentResolver resolver = this.getContentResolver();
resolver.takePersistableUriPermission(data.getData(),takeFlags);
updateDirectoryEntries(data.getData());
} else
{
// The user cancelled the request.
}
}
}
Я получаю этот uri
"/tree/raw:/storage/emulated/0/Download/prova1"
и принимаю его за строку.
В следующий раз, когда приложение запускается, вызывается следующий метод:
public void consumeUri(String uriPath)
{
ContentResolver contentResolver;
contentResolver = this.getContentResolver();
Uri uri;
Uri docUri;
uri=Uri.parse(uriPath);
docUri= DocumentsContract.buildDocumentUriUsingTree(uri,
DocumentsContract.getTreeDocumentId(uri)); //error here
}
Я получаю эту трассировку стека:
java.lang.IllegalArgumentException: Invalid URI: /tree/raw:/storage/emulated/0/Download/prova1
at android.provider.DocumentsContract.getTreeDocumentId(DocumentsContract.java:1023)
at com.example.myapplication.MainActivity.consumeUri(MainActivity.java:123)
at com.example.myapplication.MainActivity$1.onClick(MainActivity.java:54)
at android.view.View.performClick(View.java:6330)
at android.view.View$PerformClick.run(View.java:24967)
at android.os.Handler.handleCallback(Handler.java:790)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:164)
at android.app.ActivityThread.main(ActivityThread.java:6687)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:438)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:810)
Что не так с моим кодом?