Firebase存储-永久加载图像预览

时间:2020-03-01 22:19:56

标签: firebase firebase-storage firebase-console

我最近开始使用Firebase存储和Firebase功能。现在,我一直在开发从功能到存储的文件上传。

我已经开始工作(上传已完成,文件出现在存储部分中),但是图像始终像这样(永远在右侧加载):

Print screen from firebase storage

我虽然这是我的代码中的错误。但是,如果我打开Goog​​le Cloud Platform-存储,则会显示该图像,并且可以打开并预览它。

在Firebase存储中,如果我打开图像(在图像上选择并单击“打开”),它将返回以下URL:https://console.firebase.google.com/u/0/undefined

我可能做错了什么?这是我正在使用的代码:

function uploadImage() {
    const newImageData = ""

    var mimeTypes = require('mimetypes');
    var image = newImageData,
        mimeType = image.match(/data:([a-zA-Z0-9]+\/[a-zA-Z0-9-.+]+).*,.*/)![1],
        fileName = 'test.' + mimeTypes.detectExtension(mimeType),
        base64EncodedImageString = image.replace(/^data:image\/\w+;base64,/, ''),
        imageBuffer = new Buffer(base64EncodedImageString, 'base64');

    // Instantiate the GCP Storage instance
    const { Storage } = require('@google-cloud/storage');
    const googleCloudStorage = new Storage(firebaseSettings);
    const bucket = googleCloudStorage.bucket('projectID.appspot.com');


    var file = bucket.file(fileName);
    return file.save(imageBuffer, {
        metadata: { contentType: mimeType, cacheControl: "public, max-age=300" },
        public: true,
        validation: 'md5'
    }, function (error: any) {

        if (error) {
            throw 'error';
        }

        return "https://storage.googleapis.com/share-expanses-dcc9f.appspot.com/" + fileName;
    });
}

感谢您的帮助

4 个答案:

答案 0 :(得分:1)

还无法测试Firebase给出的解决方案,但这是响应记录:

您面临的问题可能是由于两个原因。的 第一个是您如何通过Firebase上传文件 使用任何Admin SDK或通过gsutil命令进行控制台。如果使用 Admin SDK选项,此问题是已知问题,其中必需 元数据不存在,幸运的是有一种解决方法,您可以尝试 script来解决此问题。

现在,第二个与network if you are using相关 comcast,请尝试在其他网络上查看此问题是否 与此有关。

答案 1 :(得分:1)

@jean-smaug 的回答差不多完成了。根据他链接的页面 (https://www.sentinelstand.com/article/guide-to-firebase-storage-download-urls-tokens),唯一缺少的是将 firebaseStorageDownloadTokens 属性包装在 metadata 对象中。我刚刚测试了它,它工作正常? 之后无需创建访问令牌。

enter image description here

答案 2 :(得分:0)

在我的情况下,我在上传时添加了元数据,并且加载了图片中显示的元数据,但是当我在3分钟后刷新页面时,我发现它可以正确上传,因此 Cafn 解释是否正确关于元数据的问题,您应该等待它加载

  $uploadedObject=$bucket->upload($imageFile, [
            'name' => 'Image_Name',
            "metadata" => [  "contentType"=> 'image/png'],
        ]);

答案 3 :(得分:0)

将图像保存到 firebase 时,您需要在元数据中提供访问令牌:firebaseStorageDownloadTokens。它必须是一个 uuid

可以在此处找到更多信息:https://www.sentinelstand.com/article/guide-to-firebase-storage-download-urls-tokens

const { v4: uuid } = require("uuid")

function uploadImage() {
    const newImageData = ""

    var mimeTypes = require('mimetypes');
    var image = newImageData,
        mimeType = image.match(/data:([a-zA-Z0-9]+\/[a-zA-Z0-9-.+]+).*,.*/)![1],
        fileName = 'test.' + mimeTypes.detectExtension(mimeType),
        base64EncodedImageString = image.replace(/^data:image\/\w+;base64,/, ''),
        imageBuffer = new Buffer(base64EncodedImageString, 'base64');

    // Instantiate the GCP Storage instance
    const { Storage } = require('@google-cloud/storage');
    const googleCloudStorage = new Storage(firebaseSettings);
    const bucket = googleCloudStorage.bucket('projectID.appspot.com');


    var file = bucket.file(fileName);
    return file.save(imageBuffer, {
        metadata: { 
          contentType: mimeType,
          cacheControl: "public,
          max-age=300",
          // THIS IS THE LINE YOU NEED TO ADD
          firebaseStorageDownloadTokens: uuid(),
        },
        public: true,
        validation: 'md5'
    }, function (error: any) {

        if (error) {
            throw 'error';
        }

        return "https://storage.googleapis.com/share-expanses-dcc9f.appspot.com/" + fileName;
    });
}

之后,您需要点击“创建访问令牌”

enter image description here