Лучший код для обработки ошибок в NodeJs и Express - PullRequest
0 голосов
/ 03 июля 2019

У меня есть этот код для пост-запроса, когда пользователь хочет изменить свой пароль.Из-за всех случаев и рендеринга следующей страницы код получился действительно безобразным.Есть ли лучший способ структурировать это?(Он работает нормально и делает то, что я хочу.)

// Check if old password is correct
    SQL.getUserFromDB(request.session.username).then(function (results) {
        // Hash and compare with stored hash
        bcrypt.compare(request.body.oldPw, results[0].password, function (error, result) {
            // Log possible error
            if (error) console.log(error);
            if (result === true) {
                // Check if new passwords are both the same
                if (request.body.newPw === request.body.newPw2) {
                    // Call mysql function
                    SQL.changeUserPassword(request.session.username, request.body.newPw).then(function () {
                        response.render('pages/changePassword', {
                            user: request.session.username,
                            text: 'Passwort erfolgreich geändert.'
                        });
                    }).catch(function (error) {
                        console.log(error);
                        if (error == 'pw') {
                            response.render('pages/changePassword', {
                                user: request.session.username,
                                text: 'Neues Passwort zu unsicher.'
                            });
                        } else {
                            // Render error page
                            response.render('pages/changePassword', {
                                user: request.session.username,
                                text: 'Fehler beim Ändern des Passworts.'
                            });
                        }
                    });
                } else {
                    // Render error page
                    response.render('pages/changePassword', {
                        user: request.session.username,
                        text: 'Neue Passwörter stimmen nicht überein!'
                    });
                }
            } else {
                // Render error page
                response.render('pages/changePassword', {
                    user: request.session.username,
                    text: 'Altes Passwort stimmt nicht überein!'
                });
            }
        });
        // Catch sql errorsFehler beim Ändern des Passworts
    }).catch(function (error) {
        if (error) console.log(error);
        response.render('pages/errors/loginFailed');
    });

Я попытался просто установить текст в разных случаях и отобразить одну страницу с текстом внизу, однако это не сработало.

1 Ответ

0 голосов
/ 03 июля 2019

Вы можете написать функцию для визуализации операций с ошибками и вызывать ее в разных местах. Для сообщений об ошибках создайте файл конфигурации и определите их в отчете об ошибках, вызовите и используйте там, где это было необходимо.

var configError = require('./config');

function renderErrorPage () {
   response.render('pages/changePassword', {
     user: request.session.username,
     text: configError[0]
   });
}

file/config.js

exports.x = [
   'Neue Passwörter stimmen nicht überein!',
   'Altes Passwort stimmt nicht überein!',
   'Neues Passwort zu unsicher.'
]

и отобразить страницу ошибки в другом состоянии, преобразуйте в:

else {
        // Render error page
       /*response.render('pages/changePassword', {
           user: request.session.username,
           text: 'Altes Passwort stimmt nicht überein!'
        });*/

        renderErrorPage();

   }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...