【发布时间】:2017-04-09 01:46:33
【问题描述】:
我在 Raspberry Pi 上用 node.js 编写了一个服务器。 我想从中运行一个 python 脚本,但它不执行该行。在以前的实例中,我已经运行了文件,但是来到这个 socket.io 实例我无法运行文件!尽管控制台显示了从客户端传递给它的准确输出,但它无法读取文件。套接字负责移动。
/*jshint esversion: 6 */
var express = require('express');
// library for executing system calls
const spawn = require('child_process').spawn;
var XMLHttpRequest = require("xmlhttprequest").XMLHttpRequest;
app = express();
server = require('http').createServer(app);
io = require('socket.io').listen(server);
var colour = require('colors');
var ip = require('ip');
var PortNumber = 3000;
var xPos = 0, yPos = 0;
server.listen(PortNumber);
app.use(express.static('public'));
io.sockets.on('connection', function (socket) {
socket.emit('ip', {value: 'http://' + ip.address() + ':8081'});
// otp generation socket
socket.on('userEmail', function (data) {
var userEmail = data.value;
// system call to generate OTP
const OTPgeneration = spawn('python', [__dirname + '/python/OTPgeneration.py', userEmail]);
OTPgeneration.stdout.on('data', (data) => {
console.log(`${data}`);
});
});
// otp submit button socket
socket.on('userOtp', function (data) {
var userOtp = data.value;
console.log(userOtp);
// system call to generate OTP
const otpValidate = spawn('python', [__dirname + '/python/OTPvalidation.py', userOtp]);
otpValidate.stdout.on('data', (data) => {
console.log(`${data}`);
// Get last output from python file
var lastChar = `${data}`.slice(-2);
if (lastChar === '0\n') {
console.log('Wrong OTP');
}
else io.sockets.emit('otpConformation', {value: 'confirm'}); //sends the confirmation to all connected clients
});
});
// x y values socket
socket.on('servoPosition', function (data) {
servoPosition = data.value;
// servoPosition[0] is x and servoPosition[1] is y
console.log('Reveived X: ' + servoPosition[0] + ' Y: ' + servoPosition[1]);
// system call for i2c comminication
const i2cData = spawn('python', [__dirname + '/python/sendI2C.py', servoPosition[0], servoPosition[1]]);
i2cData.stdout.on('data', (data) => {
console.log(`${data}`);
});
});
// movement socket
socket.on('movement', function (data) {
var m = data.value;
console.log("Movement :" + m);
const submitMove = spawn('python', [__dirname + '/python/move.py', m]);
submitMove.stdout.on('data', (data) => {
console.log(`${data}`);
});
});
});
console.log('Server Running @'.green + ip.address().green + ":3000".green);
function readTextFile(file) {
var rawFile = new XMLHttpRequest();
//var rawFile = new XMLHttpRequest();
rawFile.open("GET", file, false);
rawFile.onreadystatechange = function () {
if(rawFile.readyState === 4) {
if(rawFile.status === 200 || rawFile.status === 0) {
allText = rawFile.responseText;
//alert(allText);
}
}
};
rawFile.send(null);
}
【问题讨论】:
-
命令失败时stderr和退出码包含什么?
-
正确 - 请同时添加这些部分以及标准输出回调:OTPgeneration.stderr.on('data', (data) => { console.log(
${data}); }); OTPgeneration.on('close', (code) => { console.log(${code}); }); -
上述代码工作正常,根据要求。套接字模块没有按预期工作。节点永远不会执行 python move.py 脚本。即使移动套接字上的控制台也可以正常工作..
标签: javascript python node.js sockets