我在nodejs上有一个函数,它从许多图像生成图像,然后从中生成pdf文件。我尝试只使用一个图像,但我需要添加更多,但这似乎不起作用
function HelperHandler() {
this.pdf = function(req, res, next) {
var doc = new PDFDocument;
mergeImages(function(err, image) {
if (err)
return res.json(err);
doc.image(image, 100, 100);
doc.output(function(string) {
res.contentType = "application/pdf";
res.send(string);
});
})
}
}
var mergeImages = function(callback) {
var Canvas = require("canvas")
, fs = require("fs");
fs.readFile(global.root_path + "/images/bg.jpg", function(err, data) {
if (err)
callback("error loading image");
else {
var canvas = new Canvas(408, 939)
, img = new Canvas.Image(data);
ctx = canvas.getContext("2d");
img.onload = function() {
ctx.drawImage(img, 0, 0, 408, 939);
}
canvas.toDataURL('image/png', function(err, str) {
callback(null, str);
});
}
});
}
错误
Error: ENAMETOOLONG, name too long ''
at Object.openSync (fs.js:427:18)
at Object.readFileSync (fs.js:284:15)
at Function.open (/Users/jtomasrl/code/app/server/node_modules/pdfkit/js/image.js:27:28)
at PDFDocument.image (/Users/jtomasrl/code/app/server/node_modules/pdfkit/js/mixins/images.js:27:26)
at /Users/jtomasrl/code/app/server/lib/handler/current/helper.js:15:11
at /Users/jtomasrl/code/app/server/lib/handler/current/helper.js:41:9
at /Users/jtomasrl/code/app/server/node_modules/canvas/lib/canvas.js:217:7
答案 0 :(得分:3)
您 可以将a buffer or a path与PDFKit图像一起使用。
但是你不能使用base64 URL,你需要将这个字符串解码为缓冲区。
使用base64数据:
doc.image(new Buffer(image.replace('data:image/png;base64,',''), 'base64'), 100, 100); // this will decode your base64 to a new buffer
有关使用节点缓冲区here的base64 de / encode的更多信息。
答案 1 :(得分:1)
错误是因为:
doc.image(image, 100, 100);
image
需要是文件的路径,而不是数据网址。
您需要分配临时文件,将画布作为PNG写入该文件,然后将该临时文件的路径名传递给doc.image(path, ...)
,然后删除临时文件。