最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

我可以让nodejs

网站源码admin31浏览0评论

我可以让nodejs

我可以让nodejs

我想使用node --debug app.js运行以下脚本,并让节点等待远程调试会话开始。我认为app.js脚本在调试器建立连接之前崩溃了。我正在使用隧道将端口5858转发到无业游民的盒子,并且我知道该部件正在工作,因为我之前已经成功使用了完全相同的设置。

这可能吗?代码在afterCheck(err,spam)) //spam is not defined崩溃,我想弄清楚原因。

var mysql      = require('mysql');
var connection = mysql.createConnection({
    host     : 'localhost',
    user     : 'root',
    password : '123',
    database : 'kommunity',
    debug: ['ComQueryPacket']
});

var akismet = require('akismet').client({ blog: 'deleted', apiKey: 'deleted' });

var selectPosts = "SELECT p.id as id, poster_ip, message, p.poster FROM topics  t\
                  LEFT JOIN posts p on t.first_post_id = p.id WHERE poster_ip != ''";

//var spam = false;

akismet.verifyKey(function(err, verified) {
    if(err) throw err;
    if (verified) {

        console.log('API key successfully verified.');
        connection.connect();

        connection.query(selectPosts, function(err, rows, fields) {
            if (err) throw err;
            var count = 0;
            rows.forEach( function(entry) {

            //console.log('foreach called with count '+count);
                count++;
                //console.log(entry['id']);

                akismet.checkSpam({
                    user_ip: entry['poster_ip'],
                    comment_author: entry['poster'],
                    comment_content: entry['message']

                    }, afterCheck(err,spam))

                });
        });

    }

    else {

        console.log('Unable to verify API key.');
    }

});

var afterDelete = function (err, rows, fields) {

    if (err) throw err;
    console.log('deleted topic '+rows[0]);
    console.log('spam');
    connection.end();

}

var afterCheck = function(err, spam, entry) {

    if(err) throw err;

console.log('after check called and spam is :'+spam);
    var deleteQuery = "DELETE FROM topics , posts  USING topics INNER JOIN posts \
                       WHERE topics.id=posts.topic_id AND topics.id ="
    if(spam) {
        console.log('spam');
        console.log('entry is ' + entry);
        connection.query(deleteQuery + entry.id + ';', afterDelete(err, rows, fields) );
        connection.end();

    } else {

        console.log('Not spam');

    }
}
回答如下:

来自Webstorm Run/Debug Help。我知道这是因为在Webstorm中调试了我的nodejs应用程序。

使用--debug-brk选项,应用程序的执行将暂停发射之后。该选项允许您调试执行的代码在开始。

使用--debug选项,必须在以下位置执行代码执行应用程序启动,然后应用程序等待调试器连接到它。当您不在时,此选项很有用现在要调试Node.js,但您想稍后对其进行调试。

2020年5月更新

[对于节点和npm版本--node 10.16.0 --npm 6.9.0,-debug-brk选项会提供弃用警告。

(node:1601) [DEP0062] DeprecationWarning: `node --debug` and `node --debug-brk` are invalid. Please use `node --inspect` or `node --inspect-brk` instead.

我们应该为此目的使用--inspect和--inspect-brk。

与本文相关的文章

发布评论

评论列表(0)

  1. 暂无评论