上传后如何使用 firebase 存储获取调整大小的 downloadUrl(Web SDK + 调整图像扩展)

Dam*_*ito 6 javascript resize firebase firebase-storage firebase-extensions

使用 Firebase Web SDK,我可以在上传文件后轻松获取 downloadUrl

const task = firebase.ref().child('myFolder').put(file, metadata)
task.then(snapshot => {
 snapshot.ref.getDownloadURL()) 
}
Run Code Online (Sandbox Code Playgroud)

但是我安装了Resize Images Extension,现在,我想在它可用时立即获取调整大小的 downloadUrl。怎么做 ?我没有找到任何关于它的解释......

rob*_*emb 9

扩展名根据您的配置方式确定性地确定新文件名。您可以在扩展的源代码 中查看有关如何确定名称的确切代码

当您安装扩展程序时,它要求提供一个相对于原始路径的调整大小图像的路径。这就是新图像的路径(当然,相对于原始图像)。

除此之外,文档指出它将以配置的宽度和高度为后缀。

使用与原始上传图像相同的名称命名调整大小的图像,但后缀为您指定的宽度和高度。

因此,如果您没有指定路径,而是指定了 200x200,然后上传image.jpg到存储桶的根目录,则新名称将是:image_200x200.jpg, 位于存储桶的根目录。

如果您指定了 path resized,并且您指定了 200x200,并且上传image2.jpg到存储桶的根目录,则新名称将/resized/image2_200x200.jpg与源图像在同一个存储桶中。

要获取下载 URL,您需要getDownloadURL在扩展函数创建新文件后使用新名称调用存储引用。

如果要等待,可以使用类似于以下的代码进行轮询:

function delay(t, v) {
  return new Promise(function(resolve) { 
    setTimeout(resolve.bind(null, v), t)
  });
}

function keepTrying(triesRemaining, storageRef) {
  if (triesRemaining < 0) {
    return Promise.reject('out of tries');
  }

  return storageRef.getDownloadURL().then((url) => {
    return url;
  }).catch((error) => {
    switch (error.code) {
      case 'storage/object-not-found':
        return delay(2000).then(() => {
          return keepTrying(triesRemaining - 1, storageRef)
        });
      default:
        console.log(error);
        return Promise.reject(error);
    }
  })
}
Run Code Online (Sandbox Code Playgroud)

这就是你在上传后调用它的方式:

const storageRef = firebase.storage().ref().child('image_200x200.jpg');
keepTrying(10, storageRef).then((url) => console.log(url));
Run Code Online (Sandbox Code Playgroud)