Ошибка необработанного отклонения NodeJS: не удается установить заголовки после их отправки


Недавно я был вовлечен в проект nodejs и при попытке использовать обещания между моими обращениями к базе данных и моей маршрутизацией я столкнулся с ошибкой Не могу установить заголовки после их отправки при запросе ответа на http://localhost:8080/api/user . Хотя я знаю о многих решениях в stack, ни одно из них не сработало для меня, поэтому вот мой код маршрутизации на маршрутизаторе .js

 server.get('/api/user/', function (req, res) {

        database.getUser()
            .then(function(data){
                res.send(data);
            }, function(err){

                res.send(500,{error: err});
            });

    });

И первая часть базы данных .js включая функцию getUser

(function() {

'use strict';
var Promise = require('bluebird'), 
    mysql = require("mysql"),
    bcrypt = require('bcryptjs'),
    client;

exports.connect = function(){
    return new Promise(function(resolve, reject) {
        client = mysql.createPool({
                connectionLimit : 100,
                waitForConnection: true,
                host     : 'localhost',
                user     : 'root',
                password : 'root',
                database : 'public',
                debug    :  false
            });
            if(!client){
                reject('Deu merda');
            }
            else{
                resolve();
            }
    });
}


exports.getUser = function(){
     return new Promise(function (resolve, reject) { 
     var query = "SELECT name FROM public.users";
     query = mysql.format(query);
     client.query(query,function (err, result) {
                if (err) {
                    reject(err);
                } else {
                    resolve(result);
                }
            });   
     });
}

Любая помощь была бы большой, заранее спасибо!

EDIT: я снова проверял свой код, и у меня есть промежуточное программное обеспечение, чтобы проверить, имеет ли пользователь разрешение на доступ к определенной странице, так как это один из последних вариантов, где я мог бы что-то изменить здесь это:

 (function() {

    'use strict';

    var routes = require("./routes"),
        cookie = require("./utils");

    module.exports = function(req, res, next) {

        var i;

        if (req.url.split('/')[1] == 'api') {

            // START REGION: API permissions (all)
            for (i = 0; i < routes.api.all.length; i++) {
                if (routes.api.all[i].indexOf(req.url) > -1) {
                    break;
                }
            }
            if (i != routes.api.all.length) {
                next();
            } else {

                // END REGION: API permissions (all)

                // START REGION: API permissions (logged)
               cookie.verifySession(req.cookies.session)
                    .then(function (userId) {

                        for (i = 0; i < routes.api.logged.length; i++) {
                            if (req.url.indexOf(routes.api.logged[i]) > -1) {
                                break;
                            }
                        }

                        if (i == routes.api.logged.length) {
                            return res.sendStatus(403);
                        } else {
                            next();
                        }

                    })
                    .catch(function (err) {
                        return res.sendStatus(403);
                    });

            }

            // END REGION: API permissions (logged)

        } else {

            // START REGION: Views permissions (all)

            cookie.verifySession(req.cookies.session)
                .catch(function (err) {
                    if (res.statusCode == null) {
                        return res.redirect('/forbidden');
                    }
                });

            for (i = 0; i < routes.views.all.length; i++) {
                if (routes.views.all[i].indexOf(req.url) > -1) {
                    break;
                }
            }

            if (i != routes.views.all.length) {
                next();
            } else {

                // END REGION: Views permissions (all)

                // START REGION: Views permissions (logged)

                cookie.verifySession(req.cookies.session)
                    .then(function (userId) {

                        for (i = 0; i < routes.views.logged.length; i++) {
                            if (req.url.indexOf(routes.views.logged[i]) > -1) {
                                break;
                            }
                        }

                        if (i == routes.views.logged.length) {
                            if (res.statusCode == null) {
                                return res.redirect('/forbidden');
                            }
                        } else {
                            next();
                        }

                    });

            }

            // END REGION: Views permissions (logged)

        }
        next();
}
}());

У меня есть вспомогательный файл, куда я добавляю разрешения:

  {
    "api":{
        "all": [
            "/api/authenticate",
            "/api/user"
        ],

        "logged": [
            "/api/lessons"
        ],

        "admin": [

        ]
    },

    "views":{
        "all": [
            "/",
            "/user_management"
        ],
        "logged": [],
        "admin": [],
        "advanced": []


    }
}
1 4

1 ответ:

Я превращу свой комментарий в ответ, поскольку это ответ на ваш вопрос:

Мне кажется, что ваше промежуточное ПО может вызывать next() несколько раз.

Вы вызываете next() в конце функции middleware. Таким образом, любой путь кода, который не попал в возврат до этого, попадет в этот next(). Но некоторые другие пути кода также имеют свои собственные вызовы next(). Это двойной вызов. В принципе, ваше промежуточное программное обеспечение не учитывает свои асинхронные операции должным образом и не имеет уникальной логики пути, которые ведут только к вызову next() или res.redirect() только один раз на запрос.