我从我的 Cloudboost 文件对象获取所有文件信息时遇到了一点问题。这是我用来获取文件的 id、名称和 url 的代码。问题是我可以取回 id 和名称;但是,URL 为空,我不知道为什么或如何修复它。任何想法??
class FileQuery extends AsyncTask<Void, Void, Void> {
@Override
protected Void doInBackground(Void... params) {
CloudQuery query = new CloudQuery("Pubs");
query.include("file");
query.equalTo("id", "U1YV132B");
try {
query.find(new CloudObjectArrayCallback() {
@Override
public void done(CloudObject[] x, CloudException t) throws CloudException {
if (x != null) {
for (int i = 0; i < x.length; i++) {
final CloudFile f = new CloudFile(x[i].getDocument());
f.fetch(new CloudFileArrayCallback() {
@Override
public void done(CloudFile[] x, CloudException t) throws CloudException {
Log.d("dozer74", "File Id: " + f.getId()); // This will print out
Log.d("dozer74", "File Name: " + f.getFileName()); // This will print out
Log.d("dozer74", "File URL: " + f.getFileUrl()); // This is null
}
});
}
}
}
});
} catch (CloudException e) {
e.printStackTrace();
}
return null;
}
}
这是我如何称呼这个类
new FileQuery().execute();
假设表 Pubs
中的列 file
实际上是 File
类型,并且您在将CloudFile
保存到 CloudBoost
之前将其保存到 Pubs
。
您现在应该像这样访问您的CloudFile
:
final CloudFile file=new CloudFile(x[i].getDocument().getJSONObject("file"));
这是因为您的线路
final CloudFile f = new CloudFile(x[i].getDocument());
只是
- 返回
CloudObject
的正文 - 使用上述步骤 #1 的输出创建
CloudFile
您缺少一个步骤,如下所示:
1.获取CloudObject
的身体 2. 检索CloudObject
内列file
下的CloudFile
正文3. 使用上述步骤 #2 的输出创建CloudFile
。
CloudObject.getFile([columnName])
在 JavaSDK-1.0.3 中作为使此操作更容易的改进之一出现,您应该能够很快从CloudBoost
存储库克隆该操作。