在测试SO 22295903中讨论的删除,垃圾功能时,我遇到了此问题。
1 /创建包含内容的文件
GoogleApiClient _gac;
DriveFile createFileWait(DriveFolder fldr, String name, String mime, byte[] buff) {
DriveFile drvFile = null;
try {
ContentsResult rslt = Drive.DriveApi.newContents(_gac).await();
if (rslt.getStatus().isSuccess()) {
Contents cont = rslt.getContents();
cont.getOutputStream().write(buff);
MetadataChangeSet meta = (mime == null) ?
new MetadataChangeSet.Builder().setTitle(name).build() :
new MetadataChangeSet.Builder().setTitle(name).setMimeType(mime).build();
drvFile = fldr.createFile(_gac, meta, cont).await().getDriveFile();
}
} catch (Exception e) {}
return drvFile;
}
2 /使用查询(它的标题)检索文件:
ArrayList<DriveId> findAll(String title, String mime, DriveFolder fldr) {
ArrayList<DriveId> dIDs = null;
if (isConnected()) try {
ArrayList<Filter> fltrs = new ArrayList<Filter>();
fltrs.add(Filters.eq(SearchableField.TRASHED, false));
if (title != null) fltrs.add(Filters.eq(SearchableField.TITLE, title));
if (mime != null) fltrs.add(Filters.eq(SearchableField.MIME_TYPE, mime));
Query qry = new Query.Builder().addFilter(Filters.and(fltrs)).build();
MetadataBufferResult rslt = (fldr == null) ? Drive.DriveApi.query(_gac, qry).await() :
fldr.queryChildren(_gac, qry).await();
if (rslt.getStatus().isSuccess()) {
MetadataBuffer mdb = null;
try {
mdb = rslt.getMetadataBuffer();
if (mdb == null) return null;
dIDs = new ArrayList<DriveId>();
for (Metadata md : mdb) {
if ((md == null) || md.isTrashed()) continue;
dIDs.add(md.getDriveId());
}
} finally { if (mdb != null) mdb.close(); }
}
} catch (Exception e) {}
return dIDs;
}
3 /您获得有效的DriveId。尝试使用它来获取在RESTful API或其他地方使用的资源ID。
String fileID = drvId.getResourceId();
您获得 null 值。片刻之后(随机,难以指定),如果您重复查询,您最终将获得您的资源ID。我知道为什么,这可能是一个延迟问题。我只是征求Google Support Team的评论。有办法获得控制权吗?查询延迟状态?
答案 0 :(得分:2)
这是因为更改首先在本地持久存储,然后在我们有足够的网络连接时(可能)以后上传到服务器。遗憾的是,在将新创建的文件提交给服务器之前,资源ID不可用。
目前你所能做的只是等待它可用。我们正在研究一些可以简化此流程的新功能,敬请期待。