Warning: file_get_contents(/data/phpspider/zhask/data//catemap/0/mercurial/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
如何在不下载的情况下从firebase存储访问文件数据_Firebase_Google Cloud Storage_Firebase Storage - Fatal编程技术网

如何在不下载的情况下从firebase存储访问文件数据

如何在不下载的情况下从firebase存储访问文件数据,firebase,google-cloud-storage,firebase-storage,Firebase,Google Cloud Storage,Firebase Storage,我的文件类型.ies有一个URL,上传到firebase存储上,我想读取文件中的内容,但当我在浏览器上点击URL时,它只返回有关文件的信息,而不是内容 示例链接: 但当我使用query params alt=media时,它会下载我不想要的内容。 是否有任何查询参数来获取文件的数据?或者以任何方式实现目标?根据文档,每次呼叫都是不同的,目的也不同: : 要列出存储桶中的对象,请执行以下操作: : 命中端点时的差别恰恰是alt=mediaparam。我的理解是,您可能希望流式传输对象?如果

我的文件类型
.ies
有一个URL,上传到firebase存储上,我想读取文件中的内容,但当我在浏览器上点击URL时,它只返回有关文件的信息,而不是内容 示例链接:

但当我使用query params alt=media时,它会下载我不想要的内容。
是否有任何查询参数来获取文件的数据?或者以任何方式实现目标?

根据文档,每次呼叫都是不同的,目的也不同:

  • :
要列出存储桶中的对象,请执行以下操作:

  • :
命中端点时的差别恰恰是
alt=media
param。我的理解是,您可能希望流式传输对象?如果是这样,您可以通过以下方式实现。例如:

要在云函数上处理该文件,您可以按照以下步骤操作,您将找到更详细的信息。作为总结,要下载文件:

// Download file from bucket.
const bucket = admin.storage().bucket(fileBucket);
const tempFilePath = path.join(os.tmpdir(), fileName);
const metadata = {
  contentType: contentType,
};
await bucket.file(filePath).download({destination: tempFilePath});
console.log('Image downloaded locally to', tempFilePath);
这将把图像保存到一个临时文件夹中,因为这是推荐的方法

使用
gcs.bucket.file(filePath).download
将文件下载到云功能实例上的临时目录。在此位置,您可以根据需要处理文件

编辑

根据:

您可以通过以下方式向云存储发送下载请求:

  • 简单下载:将对象下载到目标
  • 流式下载:将数据下载到进程
  • 切片对象下载:下载大型对象
在中,在GitHub Repo之后:它显示了一个正在下载的流:

void ReadObject(google::cloud::storage::Client client,
                std::vector<std::string> const& argv) {
  //! [read object] [START storage_download_file]
  namespace gcs = google::cloud::storage;
  [](gcs::Client client, std::string const& bucket_name,
     std::string const& object_name) {
    gcs::ObjectReadStream stream = client.ReadObject(bucket_name, object_name);

    int count = 0;
    std::string line;
    while (std::getline(stream, line, '\n')) {
      ++count;
    }

    std::cout << "The object has " << count << " lines\n";
  }
  //! [read object] [END storage_download_file]
  (std::move(client), argv.at(0), argv.at(1));
}

实际上,我不想在任何时候下载这个文件。我需要的是直接读取文件中的内容。我托管在一个不同的服务器上,该服务器提供了我想要的内容,指向该文件的链接在这里:但当我点击firebase bucket提供给我的URL时,它只提供有关该文件的信息。我现在不处理图像。顺便说一句,Joss Baron谢谢你的努力。我真的很欣赏它,也很喜欢它。请查看上述评论,并告诉我您是否可以提供帮助。很抱歉耽搁了,我用一个例子更新了答案。
// Download file from bucket.
const bucket = admin.storage().bucket(fileBucket);
const tempFilePath = path.join(os.tmpdir(), fileName);
const metadata = {
  contentType: contentType,
};
await bucket.file(filePath).download({destination: tempFilePath});
console.log('Image downloaded locally to', tempFilePath);
void ReadObject(google::cloud::storage::Client client,
                std::vector<std::string> const& argv) {
  //! [read object] [START storage_download_file]
  namespace gcs = google::cloud::storage;
  [](gcs::Client client, std::string const& bucket_name,
     std::string const& object_name) {
    gcs::ObjectReadStream stream = client.ReadObject(bucket_name, object_name);

    int count = 0;
    std::string line;
    while (std::getline(stream, line, '\n')) {
      ++count;
    }

    std::cout << "The object has " << count << " lines\n";
  }
  //! [read object] [END storage_download_file]
  (std::move(client), argv.at(0), argv.at(1));
}
const {Storage} = require('@google-cloud/storage');
const storage = new Storage();
const bucket = storage.bucket(bucket);
const remoteFile = bucket.file(file);

let buffer = '';
remoteFile.createReadStream()
  .on('error', function(err) {console.log(err)})
  .on('data', function(response) {
    buffer += response
  })
  .on('end', function() {
    //console.log(buffer);
    res.send(buffer);
  })