将标头发送到客户端后无法设置标头 - NodeJs

时间:2021-02-20 14:22:45

标签: node.js express

我正在编写一个 react.js 应用程序,就像一个博客,人们可以在其中发布帖子,就像在 Medium 平台上一样。但是,当我的用户尝试在他们的帐户中登录时,我的快速服务器返回一个错误,指出该应用程序在已发送标头后无法返回标头,但我不知道如何解决这个问题...< /p>

我的代码:

app.post("/users/login", (req, res) => {

     var ReqUsername = req.body.username;
     var ReqPassword = req.body.password;

     userModel.find((err, docs) => {
          if(!err) {

               console.log(docs)

               docs.forEach(user => {
                    console.log(user)

                    var encryptedUsername = user.username;
                    var encryptedPassowrd = user.password;

                    var bytesUsername  = CryptoJS.AES.decrypt(encryptedUsername, <SECRET KEY>);
                    var bytesPassword  = CryptoJS.AES.decrypt(encryptedPassowrd, <SECRET KEY>);

                    var decryptedUsername = bytesUsername.toString(CryptoJS.enc.Utf8);
                    var decryptedPassword = bytesPassword.toString(CryptoJS.enc.Utf8);

                    if(decryptedUsername == ReqUsername) {
                         if(decryptedPassword == ReqPassword) {
                              res.json({
                                   sucesso: true,
                                   mensagem:"Login feito com sucesso",
                                   userId: user.userId
                              }).status(202)
                         }
                         else {
                              res.json({
                                   sucesso: false,
                                   mensagem:"Por favor, confira as suas informações e tente login novamente"
                              }).status(404)
                         }
                    }
                    else {
                         res.json({
                              sucesso: false,
                              mensagem:"Por favor, confira as suas informações e tente login novamente"
                         }).status(404)
                    }

               })
          }
          else {
               res.json("Error on check user database").status(500)
          }
     })
})

使用发布登录网址后,我总是收到此错误:

2021-02-20T14:16:38.847139+00:00 app[web.1]: Error [ERR_HTTP_HEADERS_SENT]: Cannot set headers after they are sent to the client
2021-02-20T14:16:38.847140+00:00 app[web.1]:     at ServerResponse.setHeader (_http_outgoing.js:558:11)
2021-02-20T14:16:38.847140+00:00 app[web.1]:     at ServerResponse.header (/app/node_modules/express/lib/response.js:771:10)
2021-02-20T14:16:38.847141+00:00 app[web.1]:     at ServerResponse.send (/app/node_modules/express/lib/response.js:170:12)
2021-02-20T14:16:38.847141+00:00 app[web.1]:     at ServerResponse.json (/app/node_modules/express/lib/response.js:267:15)
2021-02-20T14:16:38.847142+00:00 app[web.1]:     at /app/main.js:79:35
2021-02-20T14:16:38.847142+00:00 app[web.1]:     at Array.forEach (<anonymous>)
2021-02-20T14:16:38.847142+00:00 app[web.1]:     at /app/main.js:65:21
2021-02-20T14:16:38.847143+00:00 app[web.1]:     at /app/node_modules/mongoose/lib/model.js:4857:16
2021-02-20T14:16:38.847143+00:00 app[web.1]:     at /app/node_modules/mongoose/lib/model.js:4857:16
2021-02-20T14:16:38.847144+00:00 app[web.1]:     at /app/node_modules/mongoose/lib/helpers/promiseOrCallback.js:24:16
2021-02-20T14:16:38.847144+00:00 app[web.1]:     at /app/node_modules/mongoose/lib/model.js:4880:21
2021-02-20T14:16:38.847144+00:00 app[web.1]:     at /app/node_modules/mongoose/lib/query.js:4399:11
2021-02-20T14:16:38.847145+00:00 app[web.1]:     at /app/node_modules/kareem/index.js:136:16
2021-02-20T14:16:38.847145+00:00 app[web.1]:     at processTicksAndRejections (internal/process/task_queues.js:75:11)
2021-02-20T14:16:38.847146+00:00 app[web.1]: Emitted 'error' event on Function instance at:
2021-02-20T14:16:38.847146+00:00 app[web.1]:     at /app/node_modules/mongoose/lib/model.js:4859:13
2021-02-20T14:16:38.847146+00:00 app[web.1]:     at /app/node_modules/mongoose/lib/helpers/promiseOrCallback.js:24:16
2021-02-20T14:16:38.847147+00:00 app[web.1]:     [... lines matching original stack trace ...]
2021-02-20T14:16:38.847147+00:00 app[web.1]:     at processTicksAndRejections (internal/process/task_queues.js:75:11) {
2021-02-20T14:16:38.847147+00:00 app[web.1]:   code: 'ERR_HTTP_HEADERS_SENT'
2021-02-20T14:16:38.847148+00:00 app[web.1]: }

我尝试删除一些响应,但无法正常工作。 你们能帮我解决这个错误吗?

1 个答案:

答案 0 :(得分:2)

仅仅take off some responses是不够的,每个请求必须只有一个响应。

app.post("/users/login", (req, res) => {
     var ReqUsername = req.body.username;
     var ReqPassword = req.body.password;
     userModel.find((err, docs) => {
          if(!err) {
               const user = docs.find(user => {
                    var bytesUsername  = CryptoJS.AES.decrypt(user.username, SECRET KEY);
                    var decryptedUsername = bytesUsername.toString(CryptoJS.enc.Utf8);
                    return decryptedUsername === ReqUsername;
               });
               
               if(!user) {
                    res.json({
                        sucesso: false,
                        mensagem:"Por favor, confira as suas informações e tente login novamente"
                    }).status(404)
               } else {
                    var bytesPassword  = CryptoJS.AES.decrypt(user.password, SECRET KEY);
                    var decryptedUsername = bytesUsername.toString(CryptoJS.enc.Utf8);
                    if(decryptedPassword == ReqPassword) {
                        res.json({
                            sucesso: true,
                            mensagem:"Login feito com sucesso",
                            userId: user.userId
                        }).status(202)
                    } else {
                        res.json({
                            sucesso: false,
                            mensagem:"Por favor, confira as suas informações e tente login novamente"
                        }).status(404)
                    }
               }
          } else {
               res.json("Error on check user database").status(500)
          }
     })
})