获取图片网址 Firebase 存储空间(管理员)



我必须将图片上传到Firebase存储。我没有使用网络版本的存储(我不应该使用它(。我正在使用火力基地管理员。 没问题,我毫无困难地上传文件,并在变量"file"中得到结果。

如果我访问 Firebase 存储控制台,图像就在那里。好吧。

return admin.storage().bucket().upload(filePath, {destination: 'demo/images/restaurantCover.jpg', 
metadata:{contentType: 'image/jpeg'}
public: true
}).then(file =>{
console.log(`file --> ${JSON.stringify(file, null, 2)}`);
let url = file["0"].metadata.mediaLink; // image url
return resolve(res.status(200).send({data:file})); // huge data
}) ;

现在,我有一些问题。

  1. 为什么这么多信息和这么多对象作为对upload ()方法的响应?回顾这个巨大的对象,我在元数据中找到了一个名为mediaLink的属性,它是图像的下载网址。但。。。

  2. 为什么网址与 Firebase 显示的网址不同?为什么我找不到downloadURL房产?

  3. 如何获取火力基地的网址?

火力基地:https://firebasestorage.googleapis.com/v0/b/myfirebaseapp.appspot.com/o/demo%2Fimages%2Fthumb_restaurant.jpg?alt=media&token=bee96b71-2094-4492-96aa-87469363dd2e

媒体链接: https://www.googleapis.com/download/storage/v1/b/myfirebaseapp.appspot.com/o/demo%2Fimages%2Frestaurant.jpg?generation=1530193601730593&alt=media

  1. 如果我使用mediaLink网址,不同的网址有问题吗?(从iOS和Web客户端读取,更新(

查看Google Cloud Storage: Node.js客户端文档,他们有一个指向示例代码的链接,该示例代码确切地显示了如何执行此操作。另请参阅文件类文档示例(如下(

// Imports the Google Cloud client library
const Storage = require('@google-cloud/storage');
// Creates a client
const storage = new Storage();
/**
* TODO(developer): Uncomment the following lines before running the sample.
*/
// const bucketName = 'Name of a bucket, e.g. my-bucket';
// const filename = 'File to access, e.g. file.txt';
// Gets the metadata for the file
storage
.bucket(bucketName)
.file(filename)
.getMetadata()
.then(results => {
const metadata = results[0];
console.log(`File: ${metadata.name}`);
console.log(`Bucket: ${metadata.bucket}`);
console.log(`Storage class: ${metadata.storageClass}`);
console.log(`Self link: ${metadata.selfLink}`);
console.log(`ID: ${metadata.id}`);
console.log(`Size: ${metadata.size}`);
console.log(`Updated: ${metadata.updated}`);
console.log(`Generation: ${metadata.generation}`);
console.log(`Metageneration: ${metadata.metageneration}`);
console.log(`Etag: ${metadata.etag}`);
console.log(`Owner: ${metadata.owner}`);
console.log(`Component count: ${metadata.component_count}`);
console.log(`Crc32c: ${metadata.crc32c}`);
console.log(`md5Hash: ${metadata.md5Hash}`);
console.log(`Cache-control: ${metadata.cacheControl}`);
console.log(`Content-type: ${metadata.contentType}`);
console.log(`Content-disposition: ${metadata.contentDisposition}`);
console.log(`Content-encoding: ${metadata.contentEncoding}`);
console.log(`Content-language: ${metadata.contentLanguage}`);
console.log(`Metadata: ${metadata.metadata}`);
console.log(`Media link: ${metadata.mediaLink}`);
})
.catch(err => {
console.error('ERROR:', err);
});

最新更新