SAF-监听来自云中文件夹的事件

我正在试验Storage access Framework,因为我想改进自己的应用程序,该应用程序已经迁移到SAF(尽管由于某些SAF设计缺陷或缺陷,我不得不放弃某些功能)。

现在,我希望当用户在云中的SAF文件夹中执行某项操作时通知我的应用。

目前,这纯粹是实验性的,因为通过GDrive可以拥有云文件夹的uri是出于黑客行为。

(其他云提供商似乎还没有做好SAF的准备,如果我错了,请纠正我)

在他们发布完整功能(有一个错误修复请求)之前,我只是提前工作,以便能够在系统选择器的云存储根目录上选择一个文件夹。

我创建了一个简单的应用程序,用于在云上创建SAF文件夹(目前无法在云存储上进行选择)并监听事件。

package com.example.safevents;

import android.app.activity;
import android.content.Intent;
import android.database.ContentObserver;
import android.net.Uri;
import android.os.Bundle;

import  com.google.android.material.floatingactionbutton.FloatingactionButton;
import com.google.android.material.snackbar.snackbar;

import androidx.appcompat.app.AppCompatactivity;
import androidx.appcompat.widget.Toolbar;

import android.os.Handler;
import android.util.Log;
import android.view.View;
import android.view.Menu;
import android.view.MenuItem;

public class Mainactivity extends AppCompatactivity {
activity activity;
Handler handler;
Observer observer;


class Observer extends ContentObserver {

    public Observer(Handler handler) {
        super(handler);
    }

    @Override
    public void onChange(boolean selfChange) {
        this.onChange(selfChange,null);
        Log.d("SAF","event fired; selfchange="+selfChange);
    }

    @Override
    public void onChange(boolean selfChange,Uri uri) {

        Log.d("SAF","event fired on uri="+uri.toString()+"; selfchange="+selfChange);
    }
}

public void openPickerForFolderCreation(activity activity,int requestCode) {

    Intent intent = new Intent(Intent.actION_CREATE_DOCUMENT);
    intent.setType("vnd.android.document/directory");
    intent.addflags(Intent.flaG_GRANT_PERSISTABLE_URI_PERMISSION);
    intent.addflags(Intent.flaG_GRANT_READ_URI_PERMISSION);
    intent.addflags(Intent.flaG_GRANT_WRITE_URI_PERMISSION);
    activity.startactivityForResult(intent,requestCode);
}

public Uri takePermanentReadWritePermissions(activity activity,Uri uri,int flags) {
    int takeflags = flags
            &
            (Intent.flaG_GRANT_READ_URI_PERMISSION | Intent.flaG_GRANT_WRITE_URI_PERMISSION
            );

    ;


    ContentResolver resolver = activity.getcontentResolver();
    resolver.takePersistableUriPermission(uri,takeflags);

    return uri;

}

public boolean arePermissionsGranted(activity activity,String uriString) {

    Uri uri = Uri.parse(uriString);


    ContentResolver resolver = activity.getcontentResolver();
    List<UriPermission> list = resolver.getPersistedUriPermissions();
    for (int i = 0; i < list.size(); i++) {

        if (((Uri.decode(list.get(i).geturi().toString())).equals(Uri.decode(uriString))) && list.get(i).isWritePermission() && list.get(i).isReadPermission()) {
            return true;
        }


    }

    return false;
}
@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    Toolbar toolbar = findViewById(R.id.toolbar);
    setSupportactionBar(toolbar);
    activity=this;
    FloatingactionButton fab = findViewById(R.id.fab);
    fab.setOnClicklistener(new View.OnClicklistener() {
        @Override
        public void onClick(View view) {
            snackbar.make(view,"Replace with your own action",snackbar.LENGTH_LONG)
                    .setaction("action",null).show();
            SAFUtils.openPickerForFolderCreation(activity,0);
        }
    });
}

@Override     受保护的void onDestroy()     {         super.onDestroy();     //重要         getcontentResolver()。unregisterContentObserver(observer);     }

@Override
protected void onactivityResult(int requestCode,int resultCode,Intent returnedIntent)
{
Log.d("SAF","picker returned "+resultCode+" "+requestCode);
if (returnedIntent!=null) Log.d("SAF","intent="+returnedIntent.toString());
if (returnedIntent.getData()!=null) Log.d("SAF","uri="+returnedIntent.getData().toString());

//resultCode is -1
    if (resultCode==-1)
        if (requestCode==0)
        {

            Uri uri=SAFUtils.takePermanentReadWritePermissions(activity,returnedIntent.getData(),returnedIntent.getflags());

            Log.d("SAF","read/write permissions="+SAFUtils.arePermissionsGranted(activity,uri.toString()));

            handler=new Handler(){};

            observer=new Observer(handler);
            getcontentResolver().
                    registerContentObserver(
                            uri,true,observer);
        }
}

@Override
public boolean onCreateOptionsMenu(Menu menu) {

    getMenuInflater().inflate(R.menu.menu_main,menu);
    return true;
}

@Override
public boolean onOptionsItemSelected(MenuItem item) {

    int id = item.getItemId();


    if (id == R.id.action_settings) {
        return true;
    }

    return super.onOptionsItemSelected(item);
}
}

我得到以下日志行:

com.example.safevents D/SAF: picker returned -1 0
com.example.safevents D/SAF: intent=Intent { dat=content://com.google.android.apps.docs.storage/document/acc=3;doc=encoded=randomalphanumericsequence= flg=0x43 }
com.example.safevents D/SAF: uri=content://com.google.android.apps.docs.storage/document/acc%3D3%3Bdoc%3Dencoded%3Dthesamealphanumericsequence%3D
com.example.safevents D/SAF: read/write permissions=true

但是在创建的文件夹内进行一些简单的文件操作后,我没有收到任何事件通知。

请注意resultCode = -1。

还请注意,省略对takePersistentPermissions方法的调用不会导致任何权限,这是由实用程序功能(检查它们未在列表中找到uri)导致的。

上面的代码有什么问题吗?

创建SAF云文件夹是否会使其无法使用?

是否有可能进一步迫使它起作用,以便对其进行大致的预先测试?

SAF功能当前不可用吗?

huli234 回答:SAF-监听来自云中文件夹的事件

暂时没有好的解决方案,如果你有好的解决方案,请发邮件至:iooj@foxmail.com
本文链接:https://www.f2er.com/3145501.html

大家都在问