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 中所有类似的问题都有我已经尝试过的类似解决方案。任何帮助将不胜感激。谢谢。
我终于解决了我的问题。事实上,我的脚本没有任何问题,一切都很完美。
发生的事情是,在删除 firestore 中的相应项目后使用云函数自动删除我的存储映像之前,我在 android 代码中有一个函数可以完成所有工作。
现在,在编写我的云功能后,我忘记编辑我的 Android 应用程序代码以不删除存储映像。
因此,从 Android 代码中删除的速度比云函数要快,并且当云函数完成作业时,该文件已不存在。
所以现在我理解了“我们只是人类”这句话
这个错误让我花了整整一周的时间。
(还删除对我不起作用的文件夹,并且没有得到这样的对象。仅删除文件有效)
归档时间: |
|
查看次数: |
2082 次 |
最近记录: |