2

当然,我一直在尝试使用 Passport-local 和 node.js 执行一些身份验证。但是,我不断收到以下错误:

Error: Can't set headers after they are sent.
    at ServerResponse.OutgoingMessage.setHeader (http.js:689:11)
    at ServerResponse.header (/home/denny/workspace/nodejs-ecommerce/e-shop/node_modules/express/lib/response.js:717:10)
    at ServerResponse.res.location (/home/denny/workspace/nodejs-ecommerce/e-shop/node_modules/express/lib/response.js:831:8)
    at ServerResponse.redirect (/home/denny/workspace/nodejs-ecommerce/e-shop/node_modules/express/lib/response.js:870:8)
    at complete (/home/denny/workspace/nodejs-ecommerce/e-shop/node_modules/passport/lib/middleware/authenticate.js:241:26)
    at /home/denny/workspace/nodejs-ecommerce/e-shop/node_modules/passport/lib/middleware/authenticate.js:250:15
    at pass (/home/denny/workspace/nodejs-ecommerce/e-shop/node_modules/passport/lib/authenticator.js:427:14)
    at Authenticator.transformAuthInfo (/home/denny/workspace/nodejs-ecommerce/e-shop/node_modules/passport/lib/authenticator.js:449:5)
    at /home/denny/workspace/nodejs-ecommerce/e-shop/node_modules/passport/lib/middleware/authenticate.js:247:22
    at /home/denny/workspace/nodejs-ecommerce/e-shop/node_modules/passport/lib/http/request.js:51:7

我的代码如下:

passport.use(new LocalStrategy({usernameField:'email', passwordField: 'password'},
    function(email, password, done) {
    User.find({ where: { email: email }}).success(function(user) {
          if (!user) {
            done(null, false, { message: 'Unknown user' });
          } 
          else if (password != user.password) {
            done(null, false, { message: 'Invalid password'});
          } 
          else {
            done(null, user);
          }
            }).error(function(err){
          done(err);
        });
        return done(null, false);
    }
));
4

1 回答 1

3

您正在调用done()回调两次。在你的 if 语句中,然后是最后一个。

不需要最后一个,因为 if/else 和 success/error 的逻辑应该总是做一些事情。

passport.use(new LocalStrategy({
        usernameField: 'email',
        passwordField: 'password'
    },
    function(email, password, done) {
        User.find({
            where: {
                email: email
            }
        }).success(function(user) {
            if (!user) {
                done(null, false, {
                    message: 'Unknown user'
                });
            } else if (password != user.password) {
                done(null, false, {
                    message: 'Invalid password'
                });
            } else {
                done(null, user);
            }
        }).error(function(err) {
            done(err);
        });
    }
));
于 2014-08-28T13:46:12.590 回答