在我的应用程序中,我发出一个http请求,一切正常,在愉快的场景中。但是当我提供错误的数据以故意填充错误时,它会在node.js服务器控制台中显示错误,但不会将错误消息发送到Web控制台。
在我的Angularjs中,我在角度控制器函数中放置如下的$ http请求。
$http({
url: '/startprocess',
method: "POST",
data: {host: 'XX.XX.XX.XXX', user: 'XX', pass: 'YYYY'},
crossDomain: true,
//timeout: 1,
headers: {'Content-Type': 'application/json','charset' : 'utf-8'}
}).then(function(response) {
console.log('success in startprocess');
$scope.mydata = response;
}, function(response) {
console.log('error in startprocess');
console.log(response);
});
在app.js
var startprocess = require('./routes/startprocess');
app.use('/startprocess', startprocess);
在路径文件夹中,我有startprocess.js
代码低于
var express = require('express');
var router = express.Router();
var SSH = require('simple-ssh');
router.post('/startprocess', function(req, res){
ssh = new SSH({
host: req.body.host,
user: req.body.user,
pass: req.body.pass
});
ssh.exec('ls', {
out: function(stdout) {
console.log(stdout);
}
}).start();
ssh.on('error', function(err) {
console.log('In Start, something went wrong.');
console.log(err);
//res.setHeader('Content-Type', 'application/json');
res.send({ data: err })
ssh.end();
});
});
请建议我更好地处理错误。如果收到错误,我想显示一些警报。我注意到,如果出现错误,它会在服务器控制台In Start, something went wrong.
上显示错误,但在Chrome控制台中显示“success in startprocess
”。
由于
答案 0 :(得分:0)
您提供的两个回调是成功和错误回调。如果响应代码不在200和299之间,则会发生错误回调。默认情况下,错误代码为200,因此在致电res.status(400)
之前,您需要将响应代码设置为res.send
或类似代码。
因此,您创建的{ data: err }
对象可能位于第一个回调中的response
变量中。