Firebase Storage - Image preview is permenantly loading

前端 未结 3 1216
旧时难觅i
旧时难觅i 2021-01-21 23:03

I\'ve started working with firebase storage and firebase functions recently. Right now I\'ve been developing file upload from functions to storage .

I\'ve got it working

3条回答
  •  隐瞒了意图╮
    2021-01-21 23:40

    When you save an image to firebase, you need to provide an access token in metadata : firebaseStorageDownloadTokens. It has to be an uuid.

    More info can be found here : 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;
        });
    }
    

    After that you'll need to click on "Create access token"

提交回复
热议问题