传递到我的 Google 云函数的 event
只真正告诉我存储桶和文件的名称,以及文件是否被删除。是的,还有更多,但似乎并没有那么有用:
{ timestamp: '2017-03-25T07:13:40.293Z',
eventType: 'providers/cloud.storage/eventTypes/object.change',
resource: 'projects/_/buckets/my-echo-bucket/objects/base.json#1490426020293545',
data: { kind: 'storage#object',
resourceState: 'exists',
id: 'my-echo-bucket/base.json/1490426020293545',
selfLink: 'https://www.googleapis.com/storage/v1/b/my-echo-bucket/o/base.json',
name: 'base.json',
bucket: 'my-echo-bucket',
generation: '1490426020293545',
metageneration: '1',
contentType: 'application/json',
timeCreated: '2017-03-25T07:13:40.185Z',
updated: '2017-03-25T07:13:40.185Z',
storageClass: 'STANDARD',
size: '548',
md5Hash: 'YzE3ZjUyZjlkNDU5YWZiNDg2NWI0YTEyZWZhYzQyZjY=',
mediaLink: 'https://www.googleapis.com/storage/v1/b/my-echo-bucket/o/base.json?generation=1490426020293545&alt=media', contentLanguage: 'en', crc32c: 'BQDL9w==' }
}
如何获取内容,而不仅仅是上传到 gs 存储桶的新 .json 文件的元数据?
我尝试在 event.data.selfLink
上使用 npm:request()
,它是存储桶中文件的 URL,但返回了授权错误:
"code": 401, "message": "匿名用户没有 storage.objects.get 对象 my-echo-bucket/base.json 的访问权限。"
SO 上有一个关于读取存储桶的类似问题,但可能在不同的平台上。无论如何,它未得到答复:
How do I read the contents of a file on Google Cloud Storage using javascript `
最佳答案
您需要为 google 存储使用客户端库,而不是通过 URL 访问。对 URL 使用 request()
只有在文件公开访问时才有效。
在包含您的项目的 npm 管理目录中导入 google 云存储库。
npm i @google-cloud/storage -S
npm page for google-cloud/storage有不错的例子,但我必须稍微通读一下 API 才能看到一种简单的下载到内存的方法。
在 Google Cloud Functions 环境中,您无需在初始化时向存储提供任何 api key 等。
const storage = require('@google-cloud/storage')();
传递的有关文件的元数据可用于确定您是否真的需要该文件。
当你想要这个文件时,你可以用 file.download 下载它函数,它可以接受回调,也可以在没有回调的情况下返回一个 promise 。
但是,数据作为 Buffer
返回,因此您需要调用 data.toString('utf-8')
将其转换为 utf-8 编码的字符串。
const storage = require('@google-cloud/storage')();
exports.logNewJSONFiles = function logNewJSONFiles(event){
return new Promise(function(resolve, reject){
const file = event.data;
if (!file){
console.log("not a file event");
return resolve();
}
if (file.resourceState === 'not_exists'){
console.log("file deletion event");
return resolve();
}
if (file.contentType !== 'application/json'){
console.log("not a json file");
return resolve();
}
if (!file.bucket){
console.log("bucket not provided");
return resolve();
}
if (!file.name){
console.log("file name not provided");
return resolve();
}
(storage
.bucket(file.bucket)
.file(file.name)
.download()
.then(function(data){
if (data)
return data.toString('utf-8');
})
.then(function(data){
if (data) {
console.log("new file "+file.name);
console.log(data);
resolve(data);
}
})
.catch(function(e){ reject(e); })
);
});
};
部署如预期:
gcloud beta functions deploy logNewJSONFiles --stage-bucket gs://my-stage-bucket --trigger-bucket gs://my-echo-bucket
记得查看 Google Cloud Platform 上的 Stackdriver:Logging 页面以获取 console.log
条目。
更新:(2019 年)当云函数首次发布时,它们在 ECONNRESET
方面遇到了一些问题。我认为现在已经解决了。如果没有,请使用类似 npm:promise-retry
关于javascript - 如何从云函数中读取 .json 类型的新云存储文件的内容?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43014341/