因此,我和我的团队正在努力尝试使用云功能将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没有正确呈现或检索。这是两个文件的网址
SVG:https://firebase storage . Google APIs . com/v 0/b/in faque-playground . appspot . com/o/testSvg/axomcbg 7 iy 6 q 8 q 8 p-5c6d . SVG?alt =媒体
PNG:https://firebase storage . Google APIs . com/v 0/b/in faque-playground . app spot . com/o/testSvg/sbbcDN _ 8 zipwlfudywew . PNG?alt =媒体
根据您的屏幕截图,SVG图像作为内容类型图像/ 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应该是这样的:

并且由于< code> 符号的原因,您所使用的代码不会适当地处理该模式:
const base64EncodedImageString = image.replace(
/^data:image\/\w+;base64,/,
""
);
请看结果如何包含< code >数据:image/SVG XML;base64,信息作为前缀:
为了成功处理SVG用例,您可以将正则表达式修改为:
const base64EncodedImageString = image.replace(
/^data:image\/(\w|\+)+;base64,/,
""
);
请注意base64现在是如何成功提取的:
如果内容类型不是像< code>image/svg xml那样设置的,请考虑将其更改为该值,这也会有所帮助。
我正在firebase中开发一个应用程序。创建订单时,我希望生成其发票。我已经实现了这个功能,但是URL有问题,因为pdf是创建的,但是正如你在图片中看到的,打开它的URL是错误的。 这是我在云函数index.js中的代码: 如你所见,pdf创建正确,但网址是错误的,我不能打开它。 如果有人帮助我,我将非常感激。
错误:(gcloud.functions.deploy)operationerror:code=7,message=没有足够的权限(重新)配置触发器(bucket ing-auto权限被拒绝)。请将所有者权限授予bucket的编辑器角色,然后再试一次。 对于云中使用的服务帐户,函数拥有对bucket所在项目的所有者访问权限。 也就是说,有两个项目,project-a和Project-B。需要在Pr
null 云存储桶是云功能工作所必需的吗?如果没有,我怎么能回到这些变化发生之前的地方。请引导我。
但是如何使用Firebase来使用不由Firebase管理的现有存储桶(尽管它拥有与创建Firebase应用程序所使用的相同的谷歌云账户的管理员访问权限)?
我已经阅读了与此相关的所有其他答案。但这对我不起作用,或者我只是不明白一些事情。请帮忙。 我正在从客户端发送'image/png'base64字符串。它是这样的:“Ivborw0kggoaaansuheugaaaaaaaaaaa……” 在云函数我有方法: 有什么不对劲?