Node.js如何从快速路由器向Web控制台发送错误消息

时间:2018-05-31 16:28:25

标签: node.js express-router

在我的应用程序中,我发出一个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”。

由于

1 个答案:

答案 0 :(得分:0)

您提供的两个回调是成功和错误回调。如果响应代码不在200和299之间,则会发生错误回调。默认情况下,错误代码为200,因此在致电res.status(400)之前,您需要将响应代码设置为res.send或类似代码。

因此,您创建的{ data: err }对象可能位于第一个回调中的response变量中。