【发布时间】:2019-01-14 19:18:02
【问题描述】:
我需要使用 HummusJS 将 png 注入 PDF。
在我的 API 的生产版本中,我将收到一个包含 base64 的发布请求,我将把它转换为二进制读取器流。 (在下面的示例中,我使用的是从本地文件中读取的测试。)
这是我的测试输入流(在“创建”对象工厂中定义):
hummusReadStreamObject (filePath) {
let fileData = fs.readFileSync(filePath).toString('hex');
let result = []
for (var i = 0; i < fileData.length; i+=2) {
result.push('0x'+fileData[i]+''+fileData[i+1])
}
return new hummus.PDFRStreamForBuffer(result)
},
我生成一个 PNG(我已经确认,PNG 已写入且有效),然后在流的“finally”事件期间执行修改
png.on('finish', function () {
create.modifiedPDFResponseStream({
pngFileName,
readStream: create.hummusReadStreamObject('/foo/file/path'),
res
})
})
modifiedPDFResponseStream 现在拉入 png 并应该将其附加到文件中:
modifiedPDFResponseStream ({ pngFileName, readStream, res }) {
const writeStream = new hummus.PDFStreamForResponse(res)
const pdfWriter = hummus.createWriterToModify(
readStream,
writeStream,
{ log: `path/to/error.txt` })
debugger
const pageModifier = new hummus.PDFPageModifier(pdfWriter,0);
if (pngFileName) {
const ctx = pageModifier.startContext().getContext()
ctx.drawImage(2, 2, `./path/to/${pngFileName}`)
pageModifier.endContext().writePage()
pdfWriter.end()
}
}
我感觉我已经接近解决方案了,错误日志没有报告任何问题,但是我在通过 Chrome 调试时收到以下异常:
events.js:183 Uncaught Error: write after end
at write_ (_http_outgoing.js:622:15)
at ServerResponse.write (_http_outgoing.js:617:10)
at PDFStreamForResponse.write
问题是否与在 .png 的 .on('finish', ...) 事件期间填充流这一事实有关?如果是这样,我可以采取一种同步方法来缓解这个问题吗?
【问题讨论】: