Node.js 错误:发送到节点后无法设置标题

Node.js 错误:发送到节点后无法设置标题,node.js,Node.js,当我发布新事件时,它会被创建,排序函数也会正常工作,但当我调用搜索函数时,我希望它与名称和位置进行比较,但不会与位置进行比较。有什么办法可以同时检查这两种情况吗?当我想创建一个新事件时,在进行排序或搜索之后,它会给出以下错误。我是新来的。帮我解决这两个错误。 server.js api.js 错误 在/api/search路由中,您并行执行两个Event.find,并且在每个Event.find的回调中,您都响应相同的http请求 因此,您需要: 具有第三个回调,该回调仅在两个Event.fin

当我发布新事件时,它会被创建,排序函数也会正常工作,但当我调用搜索函数时,我希望它与名称和位置进行比较,但不会与位置进行比较。有什么办法可以同时检查这两种情况吗?当我想创建一个新事件时,在进行排序或搜索之后,它会给出以下错误。我是新来的。帮我解决这两个错误。 server.js

api.js

错误

在/api/search路由中,您并行执行两个Event.find,并且在每个Event.find的回调中,您都响应相同的http请求

因此,您需要:

具有第三个回调,该回调仅在两个Event.finds都已完成时调用,因此您只在那里响应一次请求,或者 按顺序执行Event.finds,方法是将其中一个放在另一个的回调中,并且只在最内部的回调中响应请求,或者 仅执行一个Event.find,方法是检查任一字段。例如:

api.post('/search', function (req, res) {
  Event.find({
    $or: [ {'name': req.body.name}, {'location': req.body.name} ]
  }, function (err, events) {
    if (err)
      return res.json(err);
    else
      res.json(events);
  });
});

谢谢为我工作:
var User= require('../models/user');
var Event=require('../models/event');
var config=require('../../config');

var secret=config.secretKey;

module.exports=function(app,express,underscore,lodash) {
    var api = express.Router();
    // app.use()

    api.post('/signup', function (req, res) {
        var user = new User({
            name: req.body.name,
            username: req.body.username,
            password: req.body.password
        });
        user.save(function (err) {
            if (err) {
                res.send(err);
                return;
            }
            res.json({
                message: 'User created!'
            });
        });

    });
    api.get('/users', function (req, res) {
        User.find({}, function (err, users) {
            if (err) {
                res.send(err);
                return;
            }
           res.json(users);
        });
    });
/*    api.get('search',function(req,res){
        search: req.body.search;
        if(search==)
    });*/


    api.post('/eventfeed', function (req, res) {
        var event = new Event({
            name: req.body.name,
            location: req.body.location,
            description: req.body.description,
            price: req.body.price,
            rating: req.body.rating
        });

        event.save(function (err) {
            if (err) {
                res.send(err);
                return;
            }
            res.json({
                message: 'Event created!'
            });
        });
    });
    api.get('/event', function (req, res) {
        Event.find({}, function (err, event) {
            if (err) {
                res.send(err);
                return;
            }
            res.json(event);
        });
    });
api.get('/sortby_price', function (req, res) {
    Event.find({}, function (err, events) {
        if (err) {
            res.send(err);
            return;
        }

        var ascending = true;//change to false for descending
        events.sort(function (a, b) {
            return (a.price - b.price) * (ascending ? 1 : -1);
                });

            res.json(events);
         });
    });
    api.get('/sortby_rating', function (req, res){
        Event.find({}, function (err, events) {
            if (err) {
                res.send(err);
                return;
            }

            var ascending = true;//change to false for descending
            events.sort(function (a, b) {
                return (a.rating - b.rating) * (ascending ? 1 : -1);
            });

            res.json(events);
        });
    });

    api.post('/search', function (req, res) {

        Event.find({'name':req.body.name},function (err, events) {

            if (err)
                return res.json(err);
            else
                res.json(events);
        });
           Event.find({'location':req.body.name},function (err, events) {

                if (err)
                    return res.json(err);
                else
                    res.json(events);

                console.log("name is" + req.body.name);
            });

        });

 return api;

}
http_outgoing.js:335
    throw new Error('Can\'t set headers after they are sent.');
          ^
Error: Can't set headers after they are sent.
    at ServerResponse.OutgoingMessage.setHeader (_http_outgoing.js:335:11)
    at ServerResponse.header (c:\Users\MY LAPY\WebstormProjects\Main\node_modules\express\lib\response.js:718:10)
    at ServerResponse.send (c:\Users\MY LAPY\WebstormProjects\Main\node_modules\express\lib\response.js:163:12)
    at ServerResponse.json (c:\Users\MY LAPY\WebstormProjects\Main\node_modules\express\lib\response.js:249:15)
    at Query.<anonymous> (c:\Users\MY LAPY\WebstormProjects\Main\app\routes\api.js:209:25)
    at c:\Users\MY LAPY\WebstormProjects\Main\node_modules\mongoose\node_modules\kareem\index.js:177:19
    at c:\Users\MY LAPY\WebstormProjects\Main\node_modules\mongoose\node_modules\kareem\index.js:109:16
    at process._tickCallback (node.js:355:11)
api.post('/search', function (req, res) {
  Event.find({
    $or: [ {'name': req.body.name}, {'location': req.body.name} ]
  }, function (err, events) {
    if (err)
      return res.json(err);
    else
      res.json(events);
  });
});