仅使用云功能的 Firebase 存储 svg 上传不起作用其他格式使用 base64 没问题
Firebase storage using cloud function only svg upload not working other format's are okay using base64
所以我和我的团队非常努力地使用云函数将 SVG 上传和检索到 firebase 存储。使用我们构建的功能,我们能够上传除 SVG 之外的任何我们想要的图像。出于某种原因,SVG 无法正常工作我不知道是我们编码有误还是其他原因
这是我的函数文件
const admin = require("firebase-admin");
const { nanoid } = require("nanoid");
const mime = require("mime-types");
const { validateCauseImageFile } = require("./fileTypeUtils");
const { imageStorageUrlMatch } = require("./regularExpression");
module.exports.imageValidationAndUpload = async (image) => {
try {
console.log("Image in base 64", image);
const bucket = admin.storage().bucket();
const mimeType = image.match(/data:([a-zA-Z0-9]+\/[a-zA-Z0-9-.+]+).*,.*/)
? image.match(/data:([a-zA-Z0-9]+\/[a-zA-Z0-9-.+]+).*,.*/)[1]
: null;
const fileExtension = mime.extension(mimeType);
console.log(fileExtension);
const fileName = nanoid() + `.${fileExtension}`;
console.log("Mime type", mimeType);
const base64EncodedImageString = image.replace(
/^data:image\/\w+;base64,/,
""
);
const imageBuffer = Buffer.from(base64EncodedImageString, "base64");
const result = await validateCauseImageFile(imageBuffer.length, mimeType);
if (result.success) {
const token = nanoid();
const options = {
gzip: true,
metadata: {
contentType: mimeType,
metadata: {
firebaseStorageDownloadTokens: token,
},
},
};
const filePath = "testSvg/" + fileName;
const file = bucket.file(filePath);
await file.save(imageBuffer, options);
const response = await file.getSignedUrl({
action: "read",
expires: "03-17-2025", // this is an arbitrary date
});
return { success: true, response: response[0] };
// return response;
} else if (image.match(imageStorageUrlMatch)) {
return { success: true, url: image };
} else {
const errorObject = { status: 403, message: result.message };
throw errorObject;
}
} catch (err) {
console.log("show error message : ", err.message);
return { success: false, message: err.message };
}
};
如果我上传 png/jpeg/jpg 图片,那么它会被上传并正常工作,但对于 SVG,它会被上传但不会呈现任何东西。在 firebase 存储控制台存储桶上,它是这样显示的
对于 SVG 图片
对于 png 或任何其他图像
上传过程正常,但 SVG 未正确呈现或检索。这是两个文件 URL 的
根据您的屏幕截图,SVG 图像作为内容类型传输 image/svg+xml
。
根据你的代码,这个内容类型计算如下:
const mimeType = image.match(/data:([a-zA-Z0-9]+\/[a-zA-Z0-9-.+]+).*,.*/)
? image.match(/data:([a-zA-Z0-9]+\/[a-zA-Z0-9-.+]+).*,.*/)[1]
: null;
意思是你的图片数据URL应该是这样的:

由于 +
符号,您正在使用的代码无法正确处理该模式:
const base64EncodedImageString = image.replace(
/^data:image\/\w+;base64,/,
""
);
请查看结果如何实际包含 data:image/svg+xml;base64,
信息作为前缀:
为了成功处理 SVG 用例,您可以将正则表达式修改为:
const base64EncodedImageString = image.replace(
/^data:image\/(\w|\+)+;base64,/,
""
);
请注意现在如何成功提取 base64:
如果内容类型没有像 image/svg+xml
那样设置,请考虑将其更改为该值,这也会有所帮助。
所以我和我的团队非常努力地使用云函数将 SVG 上传和检索到 firebase 存储。使用我们构建的功能,我们能够上传除 SVG 之外的任何我们想要的图像。出于某种原因,SVG 无法正常工作我不知道是我们编码有误还是其他原因
这是我的函数文件
const admin = require("firebase-admin");
const { nanoid } = require("nanoid");
const mime = require("mime-types");
const { validateCauseImageFile } = require("./fileTypeUtils");
const { imageStorageUrlMatch } = require("./regularExpression");
module.exports.imageValidationAndUpload = async (image) => {
try {
console.log("Image in base 64", image);
const bucket = admin.storage().bucket();
const mimeType = image.match(/data:([a-zA-Z0-9]+\/[a-zA-Z0-9-.+]+).*,.*/)
? image.match(/data:([a-zA-Z0-9]+\/[a-zA-Z0-9-.+]+).*,.*/)[1]
: null;
const fileExtension = mime.extension(mimeType);
console.log(fileExtension);
const fileName = nanoid() + `.${fileExtension}`;
console.log("Mime type", mimeType);
const base64EncodedImageString = image.replace(
/^data:image\/\w+;base64,/,
""
);
const imageBuffer = Buffer.from(base64EncodedImageString, "base64");
const result = await validateCauseImageFile(imageBuffer.length, mimeType);
if (result.success) {
const token = nanoid();
const options = {
gzip: true,
metadata: {
contentType: mimeType,
metadata: {
firebaseStorageDownloadTokens: token,
},
},
};
const filePath = "testSvg/" + fileName;
const file = bucket.file(filePath);
await file.save(imageBuffer, options);
const response = await file.getSignedUrl({
action: "read",
expires: "03-17-2025", // this is an arbitrary date
});
return { success: true, response: response[0] };
// return response;
} else if (image.match(imageStorageUrlMatch)) {
return { success: true, url: image };
} else {
const errorObject = { status: 403, message: result.message };
throw errorObject;
}
} catch (err) {
console.log("show error message : ", err.message);
return { success: false, message: err.message };
}
};
如果我上传 png/jpeg/jpg 图片,那么它会被上传并正常工作,但对于 SVG,它会被上传但不会呈现任何东西。在 firebase 存储控制台存储桶上,它是这样显示的
对于 SVG 图片
对于 png 或任何其他图像
上传过程正常,但 SVG 未正确呈现或检索。这是两个文件 URL 的
根据您的屏幕截图,SVG 图像作为内容类型传输 image/svg+xml
。
根据你的代码,这个内容类型计算如下:
const mimeType = image.match(/data:([a-zA-Z0-9]+\/[a-zA-Z0-9-.+]+).*,.*/)
? image.match(/data:([a-zA-Z0-9]+\/[a-zA-Z0-9-.+]+).*,.*/)[1]
: null;
意思是你的图片数据URL应该是这样的:

由于 +
符号,您正在使用的代码无法正确处理该模式:
const base64EncodedImageString = image.replace(
/^data:image\/\w+;base64,/,
""
);
请查看结果如何实际包含 data:image/svg+xml;base64,
信息作为前缀:
为了成功处理 SVG 用例,您可以将正则表达式修改为:
const base64EncodedImageString = image.replace(
/^data:image\/(\w|\+)+;base64,/,
""
);
请注意现在如何成功提取 base64:
如果内容类型没有像 image/svg+xml
那样设置,请考虑将其更改为该值,这也会有所帮助。