来自node.js的phantomjs调用uing spawn似乎没有执行脚本

来自node.js的phantomjs调用uing spawn似乎没有执行脚本,node.js,phantomjs,pdf-generation,Node.js,Phantomjs,Pdf Generation,我正在尝试从动态把手网页生成一个pdf文件,该网页将显示数据库中的数据。一旦我在本地机器上实现了这个功能,我想将代码升级到elastic beanstalk。最初调用spawn的代码似乎在运行,但是,调用phantomjs似乎并没有启动传递给它的脚本。为了确认这一点,我在文件的最开始添加了一个console.log语句,但从未打印出来。更不用说脚本文件中的另一个print语句了。代码如下: code that performs the spawn: var childArgs = [

我正在尝试从动态把手网页生成一个pdf文件,该网页将显示数据库中的数据。一旦我在本地机器上实现了这个功能,我想将代码升级到elastic beanstalk。最初调用spawn的代码似乎在运行,但是,调用phantomjs似乎并没有启动传递给它的脚本。为了确认这一点,我在文件的最开始添加了一个console.log语句,但从未打印出来。更不用说脚本文件中的另一个print语句了。代码如下:

code that performs the spawn:
var childArgs = [
                  //'--debug=true',
                  path.join(__dirname, '../phantom/capture.js'),
                  id,
                  filename
                ];

            let child = spawn(phantomjs.path, childArgs, {detached: false});

            console.log('set up stderr.....');
            child.stderr.on('data', (data) => {
              console.log('ps stderr: ${data}');
            });

            console.log('set up stdout.....');
            child.stdout.on('data', (data) => {
              console.log('ps stdout: ${data}');
            });

            console.log('set up close.....');
            child.on('close', (code) => {
                console.log('this is a test 2.....');
                console.log(code);
                if (code !== 0){
                    let error = new Error('An error occurred while creating the current report.');
                    error.status = 500;
                    reject(error);
                }

                resolve(fname);
                return;
            });




capture.js:
console.log('we are inside....');
let os = require('os');
var system = require('system');
console.log('we are inside.... 1');
var page = require('webpage').create();
let phantom = require('phantomjs-prebuilt');
console.log('we are inside....2');
var args = system.args;
console.log('we are inside....3');

if (args.length === 1) {
  phantom.exit(0);
} else {
    page.viewportSize = { width: 2000, height: 800 };
//page.paperSize = { format: 'Letter', orientation: 'landscape', margin: '1cm' };
page.paperSize = { width: '1280px', height: '800px', margin: '0px' };
page.settings.localToRemoteUrlAccessEnabled = true;
page.settings.loadImages = true;
page.settings.javascriptEnabled = true;

let done = false;
//"http://example.com/order/" + args[1] + '?token=' + args[2]
page.open("http://example.com/order/" + args[1], function start(status) {
  if (status === "success"){
      page.render(os.tmpdir() + '/' + args[2], { format: 'pdf' });
  }

  done = true;
});

var intervalId = setInterval(function(){
    if (done){
        phantom.exit();
    } 
}, 100);
}

我不知道问题出在哪里。capture.js的第一行似乎没有被调用。1) 我遗漏了什么问题?2) 如何修复它?

问题可能是由于安全原因,PhantomJS无法使用带有点的路径运行capture.js。例如,尝试从当前目录运行capture.js