Я пытаюсь сохранить изображение base64, полученное из внешнего интерфейса angular, в каталог хранилища firebase. но изображение, сохраненное в папке firebase, по какой-то причине не создает превью. также я не могу получить подписанный URL-адрес для файла изображения при попытке его получить.
Я использую firebase admin-sdk для создания ссылки на ведро - storageRef.
Данные изображения, полученные в серверной части узла, кажутся в порядке, и я тестировал то же самое с онлайн-декодерами base64 и правильно регенерировал в исходное изображение. Может кто-нибудь сказать мне, что здесь не так?
exports.createContent = async(req, res, next) => {
// Add a new document with a generated id.
const writer = await db.collection('feeds').doc(req.body.language).collection(req.body.type).add({
author: req.body.author,
cat: req.body.cat,
content: req.body.content,
createdAt: admin.firestore.Timestamp.fromDate(new Date(req.body.createdAt)),
excerpt: req.body.excerpt,
lastEdit: admin.firestore.Timestamp.fromDate(new Date(req.body.lastEdit)),
media: req.body.media,
os_android: req.body.os_android === 'true' ? true : false,
os_ios: req.body.os_ios === 'true' ? true : false,
region: req.body.region,
status: req.body.status,
title: req.body.title,
type: req.body.type
}).then((docRef) => {
let bufferStream = new stream.PassThrough();
base64EncodedImageString = req.body.imageSrc.replace(/^data:image\/\w+;base64,/, '');
bufferStream.end(Buffer.from(base64EncodedImageString, 'base64'));
var file = storageRef.file('thumbnail/' + req.body.type + '/' + docRef.id + '.png');
//Pipe the 'bufferStream' into a 'file.createWriteStream' method.
bufferStream.pipe(file.createWriteStream({
metadata: {
contentType: 'image/png',
metadata: {
custom: 'metadata'
}
},
public: true,
validation: "md5"
}))
.on('error', function(err) {
console.log(err);
})
.on('finish', function() {
res.json({
message: "Feeds Added Successfully",
feeds: docRef.id
});
});
})
};