Я все ще намагаюся зрозуміти більш точні моменти того, як я можу запустити команду оболонки Linux або Windows та захопити вихід у node.js; врешті-решт, я хочу зробити щось подібне ...
//pseudocode
output = run_command(cmd, args)
Важливим елементом є те, що він outputповинен бути доступний глобально зміненій змінній (або об'єкту). Я спробував наступну функцію, але мені чомусь undefinedнадрукується на консолі ...
function run_cmd(cmd, args, cb) {
var spawn = require('child_process').spawn
var child = spawn(cmd, args);
var me = this;
child.stdout.on('data', function(me, data) {
cb(me, data);
});
}
foo = new run_cmd('dir', ['/B'], function (me, data){me.stdout=data;});
console.log(foo.stdout); // yields "undefined" <------
У мене виникають проблеми з розумінням того, де код пробивається вище ... працює дуже простий прототип цієї моделі ...
function try_this(cmd, cb) {
var me = this;
cb(me, cmd)
}
bar = new try_this('guacamole', function (me, cmd){me.output=cmd;})
console.log(bar.output); // yields "guacamole" <----
Чи може хтось допомогти мені зрозуміти, чому try_this()працює, а run_cmd()ні? FWIW, мені потрібно використовувати child_process.spawn, тому що child_process.execмає обмеження в буфері 200 КБ.
Остаточне рішення
Я приймаю відповідь Джеймса Уайта, але це точний код, який працював на мене ...
function cmd_exec(cmd, args, cb_stdout, cb_end) {
var spawn = require('child_process').spawn,
child = spawn(cmd, args),
me = this;
me.exit = 0; // Send a cb to set 1 when cmd exits
me.stdout = "";
child.stdout.on('data', function (data) { cb_stdout(me, data) });
child.stdout.on('end', function () { cb_end(me) });
}
foo = new cmd_exec('netstat', ['-rn'],
function (me, data) {me.stdout += data.toString();},
function (me) {me.exit = 1;}
);
function log_console() {
console.log(foo.stdout);
}
setTimeout(
// wait 0.25 seconds and print the output
log_console,
250);
me.stdout = "";вcmd_exec()запобігти конкатенаціїundefinedдо початку результату.