簡體   English   中英

在 NodeJs 和 Express 中更好的錯誤處理代碼

[英]Better code for error handling in NodeJs and Express

當用戶想要更改密碼時,我有此代碼用於發布請求。 由於所有情況和以下頁面呈現的代碼非常難看。 有沒有更好的方法來構造它? (它工作正常,可以做我想要的。)

// 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');
    });

我嘗試只在不同情況下設置文本並在底部渲染一頁文本,但這不起作用。

您可以編寫一個函數來呈現錯誤操作並在不同的地方調用它。 對於錯誤消息,創建一個配置文件並在錯誤報告中定義它們,然后在需要的地方調用和使用。

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 條件下呈現錯誤頁面轉換為:

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

        renderErrorPage();

   }

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM