当前位置: 首页 > 知识库问答 >
问题:

Firebase存储-图像预览正在频繁加载

尉迟鸿熙
2023-03-14

我最近开始使用firebase存储和firebase函数。现在我一直在开发从函数到存储的文件上传。

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

我以为这是我代码中的一个错误。然而,如果我打开谷歌云平台-存储,图像就会出现,我可以打开它并预览它。

我做错了什么?下面是我使用的代码:

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;
    });
}

谢谢你的帮助

共有1个答案

邹麻雀
2023-03-14

我还没能测试Firebase给出的解决方案,但以下是回应的文字记录:

你面临的问题可能是因为两个原因。第一个问题是如何通过Firebase控制台、使用任何管理SDK或通过gsutil命令上传文件。如果使用Admin SDK选项,问题是一个已知的问题,其中所需的元数据不存在,幸运的是有一个解决方法,您可以尝试这个脚本来解决这个问题。

现在,第二个问题与网络有关如果您正在使用康卡斯特,请在另一个网络上试试,看看这个问题是否与网络有关。

 类似资料:
  • 以下是我的上传代码: 编辑:我将base64字符串复制到一个在线转换器中,看起来不错,它返回了正确的图像。看起来,数据没有问题。firebase的处理方式有问题。 编辑:我尝试显式地将类型设置为image/jpeg而不是image/jpg,如下所述:当Firestorage关闭时显示图像的正确方式,或者在Firestorage for iOS中加载预览时出错,但没有区别。

  • ,而当我上传相同的文件从上传文件选项从firebase UI然后它是预览罚款。Pls帮助我解决这个问题。

  • 我想从Firebase存储中播放视频,其中包含我正在尝试的视频视图,如下所示: 但它不会播放。视频是空的。

  • 我试图在Firebase存储中使用Firebase上传图像,但文件不能完全上传。它只显示图像的大小9字节,下载时无法预览。 这是我使用的代码:- 我使用的反应本地图像作物选择器。我使用Firebase,但不是反应本机Firebase。请帮助!

  • 我正在开发一款用于拍照的Android应用程序。首先,用户拍摄个人资料图片。此图像的Url保存在Firebase实时数据库中。用于检索以下下载URL的示例代码 这个url被保存在数据库中的多个地方,我需要在那里加载用户的个人资料图片——他的每个帖子的条目,他给应用程序上其他人的消息,等等。 现在,如果他以后更改个人资料图片,我有以下两个选项 更新每个数据库条目-非常繁琐、暴力和资源密集 那么,有没

  • 在我的应用中,我提示用户捕获图像。用户相机活动在按钮单击时开始,用户可以选择使用相机捕获图像。 此图像保存在用户手机上。然后将图像上传到firebase Storage,一切正常。来自一位使用三星Note 8的用户的反馈是,当图像以肖像模式拍摄时,他稍后会在应用程序中以风景模式显示。 我查看了firebase存储,发现图像以横向模式保存在存储中,即使用户以纵向模式捕获图像。 我想我必须将元数据传递