Express + Passport,错误:无法向护照发送请求而不会抛出任何错误

时间:2015-12-27 18:45:05

标签: javascript node.js express passport.js

尝试使用护照的第一个时间节点签名到应用程序,并且不能在命令中得到任何错误。

负载太大后会响应:

  

未收到任何数据

     

ERR_EMPTY_RESPONSE

无法找到此错误的任何解决方案。

路由

loginRouter.route('/login')
        .get(loginController.getLogin)
        .post(loginController.postLogin);

postlogin功能:

var postLogin = function(req, res, next){
        passport.authenticate('local', {
            successRedirect: '/',
            failureRedirect: '/auth/login',
            failureFlash : true
        });
    };

passport.js

var passport = require('passport');
var localStrategy = require('passport-local').Strategy;
var bcrypt = require('bcrypt-nodejs');
var User = require('../app/models/model')().User;

module.exports = function(){

    passport.use('local',new localStrategy({
        usernameField: 'username',
        passwordField: 'password',
        passReqToCallback : true
    },
    function (username, password, done){
        User.findOne({
            where: {
                username: username
            }
        }).then(function(user){
            if(!user) {
                console.log(user);
                done(null, false, req.flash('invalid credentials try again'));
            } else if (!bcrypt.compareSync(password, user.password)) {
                done(null, false, req.flash('invalid credentials try again'));
            } else {
                done(null, user);
            }
        });
    }));

    passport.serializeUser(function (user,done) {
        done(null, user.id);
    });

    passport.deserializeUser(function (id, done){
        User.findOne({where: {id: id}}).then(function(user){
            done(null, user);
        });
    });
};

app.js

var express = require('express'),
    session = require('express-session'),
    cookieParser = require('cookie-parser'),
    bodyParser = require('body-parser'),
    passport = require('passport'),
    flash = require('express-flash'),
    app = express(),
    port = 80;


app.use(express.static(__dirname + '/public'));

app.use(bodyParser.json());
app.use(bodyParser.urlencoded( { extended: true } ));
app.use(cookieParser());
app.use(session({
    secret: 'lirary',
    cookie: {
        maxage: 1200000
    },
    resave: true,
    saveUninitialized: true
}));
app.use(passport.initialize());
app.use(passport.session());
app.use(flash());

require('./config/passport')();
app.set('views','./resources/views');
app.set('view engine','ejs');

require(__dirname + '/app/routes/routes')(app);

app.listen(port,function(err){
    console.log('server running on : '+ port)
    if (err) {
        throw err;
    };
});

1 个答案:

答案 0 :(得分:1)

我的路线变化很小,现在解决了这个问题。

loginRouter.post('/login',
        function (req, res, next) {
            console.log(User.validate());
            next();
        },
        passport.authenticate('local',{     
                successRedirect: '/dashboard',
                failureRedirect: '/auth/login',
                failureFlash : true
            }
        ));