Javascript Can';发送后不设置标题

Javascript Can';发送后不设置标题,javascript,node.js,express,Javascript,Node.js,Express,我曾尝试设置标题,但不起作用。我已经把return放在每行的末尾了。因此,它不应该执行两次res.json(data) 如果我错了,请纠正我 app.js var express = require('express'); var path = require('path'); var favicon = require('serve-favicon'); var logger = require('morgan'); var cookieParser = require('cookie-par

我曾尝试设置标题,但不起作用。我已经把return放在每行的末尾了。因此,它不应该执行两次
res.json(data)

如果我错了,请纠正我

app.js

var express = require('express');
var path = require('path');
var favicon = require('serve-favicon');
var logger = require('morgan');
var cookieParser = require('cookie-parser');
var bodyParser = require('body-parser');

var routes = require('./routes/index');
//var users = require('./routes/users');
var api = require('./routes/api');
var users_page = require('./routes/users_page');
var quizzes = require('./routes/quizzes');
var subjects = require('./routes/subjects');
var questions = require('./routes/questions');

var app = express();

// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'jade');

// uncomment after placing your favicon in /public
//app.use(favicon(__dirname + '/public/favicon.ico'));
app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));

app.use('/', routes);
//app.use('/users', users);
app.use('/api', api);
app.use('/users',users_page);
app.use('/quizzes', quizzes);
app.use('/subjects',subjects);
app.use('/questions',questions);


// catch 404 and forward to error handler
app.use(function(req, res, next) {
  var err = new Error('Not Found');
  err.status = 404;
  next(err);
});

// error handlers

// development error handler
// will print stacktrace
if (app.get('env') === 'development') {
  app.use(function(err, req, res, next) {
    res.status(err.status || 500);
    res.render('error', {
      message: err.message,
      error: err
    });
  });
}

// production error handler
// no stacktraces leaked to user
app.use(function(err, req, res, next) {
  res.status(err.status || 500);
  res.render('error', {
    message: err.message,
    error: {}
  });
});


module.exports = app;

用户\u page.js

var express = require('express');
var router = express.Router();
var pg = require('pg');
var connectionString = process.env.DATABASE_URL || 'postgres://admin:admin@localhost:5432/mydb';

var userHandler = require('./userHandler_post.js'); 
router.post('/', userHandler.post);

var usr2 = require('./userHandler_getusrinfo.js');
router.get('/:username', usr2.getusrinfo);

var usr3 = require('./userHandler_upusr.js');
router.put('/:username', usr3.upusr);


var usr4 = require('./userHandler_del.js');
router.delete('/:username', usr4.del);


var usr5 = require('./userHandler_repasswd.js');
router.put('/reset_password/:username', usr5.repasswd);


var usr6 = require('./userHandler_getall.js');
router.get('/', usr6.get);

module.exports = router;

userHandler\u getusrinfo.js:

var pg = require('pg');
var connectionString = process.env.DATABASE_URL || 'postgres://admin:admin@localhost:5432/mydb';

exports.getusrinfo = function(req, res, callback) {

    var username = req.params.username;

  pg.connect(connectionString, function(err, client, done) {
    // Handle Errors
    if(err) {
        res.setHeader('Content-Type', 'application/json');
      res.json(err);
      return ;
    }

        var q2 = client.query("SELECT * FROM dugong.users WHERE UserName =$1 ;",[username]);

        q2.on('error', function(error) {
            var data = {success : false, 
                                    username : username,
                                    reason : {errmsg : error.detail,
                                                        errid : error.code} };  
            res.setHeader('Content-Type', 'application/json');
            res.json(data);
            return callback();
        });    

      q2.on('row', function(row, result) {
          result.addRow(row);
          return ;
      });

      q2.on('end', function(result) {

          if (result.rowCount == 0) {
                    var data = {success : false, 
                                            username : username, 
                                            reason : {errmsg : "Username not found", 
                                                                errid : 'q2'}};
                    res.setHeader('Content-Type', 'application/json');
                    res.json(data);

                    return callback();
                }

                var sumdata = {success: true,
                                        username : result.rows[0].username,
                                        ... //omit to keep it short
                                        FaxNumber : result.rows[0].faxnum
                                        };
          res.setHeader('Content-Type', 'application/json');
          res.json(sumdata);
          return callback();
      });
      done();
      return ;
  });
  pg.end();
};
然而,我得到了这样一个恼人的信息。 但程序运行良好

GET /users/Sari 500 45.026 ms - 89
Error: Can't set headers after they are sent.
    at ServerResponse.OutgoingMessage.setHeader (_http_outgoing.js:335:11)
    at ServerResponse.header (/home/sarit/4alls/mariner/node_modules/express/lib/response.js:700:10)
    at ServerResponse.send (/home/sarit/4alls/mariner/node_modules/express/lib/response.js:154:12)
    at fn (/home/sarit/4alls/mariner/node_modules/express/lib/response.js:934:10)
    at View.exports.renderFile [as engine] (/home/sarit/4alls/mariner/node_modules/jade/lib/index.js:374:12)
    at View.render (/home/sarit/4alls/mariner/node_modules/express/lib/view.js:93:8)
    at EventEmitter.app.render (/home/sarit/4alls/mariner/node_modules/express/lib/application.js:566:10)
    at ServerResponse.res.render (/home/sarit/4alls/mariner/node_modules/express/lib/response.js:938:7)
    at /home/sarit/4alls/mariner/app.js:64:7
    at Layer.handle_error (/home/sarit/4alls/mariner/node_modules/express/lib/router/layer.js:58:5)

我需要触摸Express制作的app.js:64:7吗?如果是这样,我该如何正确地执行此操作?

将您的第二季度查询代码放在其他部分。

将您的第二季度查询代码放在其他部分。

如果没有更多的工作要做或出现错误,您不应该调用
回调
下一步
)函数。你的
App.js
文件中有一个catchall(我假设是因为你没有发布它),它被击中是因为你调用了
回调
next
)函数。它试图呈现一个错误页面,因此调用Jade呈现


删除
回调
调用。

如果没有更多工作要做或出现错误,则不应调用
回调
下一步
)函数。你的
App.js
文件中有一个catchall(我假设是因为你没有发布它),它被击中是因为你调用了
回调
next
)函数。它试图呈现一个错误页面,因此调用Jade呈现



删除
回调
调用。

能否共享您的App.js文件?您的错误似乎来自渲染视图。也许您正在发送JSON数据,然后尝试呈现并返回一个视图?可以是useful@ChrisAnderson-MSFT我刚刚更新了我的问题。@YannBertrand。我读过了。这就是为什么我将res.setHeader()置于res.json之上。我仍在查找其根本原因。您正在使用
res.json
并调用
callback
,这将传递给错误处理程序。您可以共享您的App.js文件吗?您的错误似乎来自渲染视图。也许您正在发送JSON数据,然后尝试呈现并返回一个视图?可以是useful@ChrisAnderson-MSFT我刚刚更新了我的问题。@YannBertrand。我读过了。这就是为什么我将res.setHeader()置于res.json之上。我仍在寻找其根本原因。您正在使用
res.json
并调用
callback
,这将传递给错误处理程序。@Kulwant。仍然是相同的错误,并且程序运行时不会像其他程序一样{}@Jan需要任何信息。我会尽快提供给你。@Sarit我还没有和node.js见过面,所以我无法回答你的问题。我只喜欢对长问题的简短回答。@sarit我想这里callback作为next,所以你next被调用。@user111111。我已经接受了你的回答,但我的名声还没有超过15岁。很奇怪,我从7月7日起就已经发表了我的评论,但它已经不见了。@Kulwant。仍然是相同的错误,并且程序运行时不会像其他程序一样{}@Jan需要任何信息。我会尽快提供给你。@Sarit我还没有和node.js见过面,所以我无法回答你的问题。我只喜欢对长问题的简短回答。@sarit我想这里callback作为next,所以你next被调用。@user111111。我已经接受了你的回答,但我的名声还没有超过15岁。很奇怪,从7月7日起我就已经发布了我的评论,但它不见了。我需要回调,因为我现在正在创建单元测试。因此,我首先创建一个检查函数来解决我的问题。谢谢:)嗨。我需要回调,因为我现在正在创建单元测试。因此,我首先创建一个检查函数来解决我的问题。谢谢:)