使用云函数删除 Firebase 存储上的文件时出现错误 No such Object

Ecc*_*nda 6 google-cloud-functions firebase-storage

这个问题已经在一些地方得到了回答,但没有一个解决方案对我有用。我也关注了官方文档。并尝试对我的代码进行故障排除一周,但我的代码似乎是正确的,只有错误不断出现,没有这样的对象

我注意到,当我使用存储触发器生成拇指生成其工作的同一图像时,我将文件路径、存储桶名称与我尝试使用 firestore 触发器删除的文件路径、存储桶名称进行了比较,发现它们是相同的。但仅在 firestore 触发器中才会以错误 No such Object 结束

这是我的代码,我不明白它有什么问题。

'use strict';
// The Cloud Functions for Firebase SDK to create Cloud Functions and setup triggers.
const functions = require('firebase-functions');

const admin = require('firebase-admin');

//var serviceAccount = require("./xproject-cdfdc-firebase-adminsdk-xxxx-xxxxx.json");
/*admin.initializeApp({
    credential: admin.credential.cert(serviceAccount),
    databaseURL: "https://xproject-cdfdc.firebaseio.com"
});*/

admin.initializeApp();

const db = admin.firestore();
const storage = admin.storage();


exports.cleanStorage = functions.firestore.document('items/{itemId}').onDelete((snapshot,context) => {

    const id = snapshot.get('itemId');
    //log: gettig id successfully
    const imageName = snapshot.get('imageName');
    //log: getting image name successfully
    const defaultBucket = storage.bucket(); 
    //log: defaultBucket.name() => xproject-cdfdc.appspot.com
    //log: My bucket is initialzed successfully and exists:
    const imageFile = defaultBucket.file('images/'+id+'/'+imageName);
    //log: imageFile.name() =>images/W0qMLHqfQANfMsbUEmihK49NFgm2_1595320646264/photo1595320646264.jpg
    //log: this path is correct and the file exists on stoarage

    return imageFile.delete().then(result =>{
        return console.log(`Deleted ${imageName}`);
    }).catch(error => {
      return console.log("Deliting  failed: error->"+error);
      //log: error->Error: No such object: xproject-cdfdc.appspot.com/images/W0qMLHqfQANfMsbUEmihK49NFgm2_1595320646264/photo1595320646264.jpg
    });
});
Run Code Online (Sandbox Code Playgroud)

所以现在我不知道我应该在我的代码中纠正什么,因为在 stackoverflow 中所有类似的问题都有我已经尝试过的类似解决方案。任何帮助将不胜感激。谢谢。

Ecc*_*nda 4

我终于解决了我的问题。事实上,我的脚本没有任何问题,一切都很完美。

发生的事情是,在删除 firestore 中的相应项目后使用云函数自动删除我的存储映像之前,我在 android 代码中有一个函数可以完成所有工作。

现在,在编写我的云功能后,我忘记编辑我的 Android 应用程序代码以不删除存储映像。

因此,从 Android 代码中删除的速度比云函数要快,并且当云函数完成作业时,该文件已不存在。

所以现在我理解了“我们只是人类”这句话

这个错误让我花了整整一周的时间。

(还删除对我不起作用的文件夹,并且没有得到这样的对象。仅删除文件有效)