我希望有人可以帮助解决这个问题,因为我自己没有得到它。
我编译了pdf2swf的最新版本,一切正常,除非我想将它用作NodeJS中的spawned child_process。
当我使用与exec相同的命令时,它再次起作用。 提供一些代码示例:
// convert a pdf to swf using exec (works)
var tmpSwfLocation = docsDir+'/Paper.pdf.swf';
var pdf2swf = cp.exec('pdf2swf '+tmpPDFLocation+' -o '+tmpSwfLocation+' -G -v -f -T 9 -t -j '+quality+' -s subpixels='+resolution+' -s storeallcharacters -s poly2bitmap', function(err, stdout, stderr){
console.log(stdout);
console.log(stderr);
var end = Date.now();
console.log('pdf2swf: SWF created in '+((end-start) /1000)+' seconds');
});
// convert a pdf to swf (does not work)
var tmpSwfLocation = docsDir+'/Paper.pdf.swf';
var pdf2swf = cp.spawn('pdf2swf', ['-G','-v','-f','-T 9', '-t', '-j '+quality,'-s subpixels='+resolution,'-s storeallcharacters', '-s poly2bitmap',tmpPDFLocation, '-o '+tmpSwfLocation],{setsid:true});
pdf2swf.stdout.on('data',function(output){
console.log("pdf2swf:"+output)
});
pdf2swf.stderr.on('data',function(output){
console.log("pdf2swf ERROR:"+output);
});
pdf2swf.stdout.on('end', function(output){
var end = Date.now();
console.log('pdf2swf: SWF created in '+((end-start) /1000)+' seconds');
});
当child_process尝试将数据写入文件时,spawn进程最终会中断:
pdf2swf:NOTICE Writing SWF file /home/bitnami/flipdoc/ec2-instances/worker/pdf_test/test_directory/test-Testfile_31MB_26Pages.pdf_0/docs/Paper.pdf.swf
pdf2swf:FATAL Could not create " /home/bitnami/flipdoc/ec2-instances/worker/pdf_test/test_directory/test-Testfile_31MB_26Pages.pdf_0/docs/Paper.pdf.swf".
使用exec,该过程使用
成功完成pdf2swf:NOTICE Writing SWF file /home/bitnami/flipdoc/ec2-instances/worker/pdf_test/test_directory/test-Testfile_31MB_26Pages.pdf_0/docs/Paper.pdf.swf
和现有文件。
其他信息: 在整个过程之前,我在整个“test_directory”上执行递归chmod 777。
迎接
答案 0 :(得分:3)
我自己解决了......从不(甚至不考虑它......)在产生过程的参数中使用空格。如果你有一个可以在中间使用空格的param = value参数,只需在数组中将它们与其他每个参数一起排列。
上面的spawn源代码现在看起来像这样:
var pdf2swf = cp.spawn('pdf2swf', [tmpPDFLocation, '-o',tmpSwfLocation,'-G','-vvv','-f','-T','9', '-t', '-j',quality,'-s','subpixels='+resolution,'-s','storeallcharacters', '-s','poly2bitmap']);