4

简而言之,我有一个登录页面,我的请求在 Express 4 中POST变成了一个。GET

这是我的登录页面的业务部分:

<form id='loginForm' action='/login' method='post'>
    <table>
        <tr>
            <td><input type='text' name='username' /></td>
        </tr>
        <tr>
            <td><input type='text' name='password' /></td>
        </tr>
        <tr>
            <td><button type='submit'>Submit</button></td>
        </tr>
    </table>
</form>

这是我设置的路线:

// Express 4    
var router = express.Router();

router.get('/login', function(req, res) {
    res.render('./login.hbs', { message: req.flash('loginMessage') });
});

router.post('/login', passport.authenticate('local-login', {
    successRedirect: '/welcome',
    failureRedirect: '/login',
    failureFlash : true
}));

passport.use('local-login',
    new LocalStrategy(
        {
            usernameField: 'email',
            passwordField: 'password',
            passReqToCallback : true
        },
        function(req, email, password, next) {
            User.findOne({ 'authLocal.email' :  email }, function(err, user) {
            console.log('Inside local-login strategy with findOne A');
            [snip]

res.render我在策略的forGET /loginfindOne()call上设置了一个断点local-login。当我单击“提交”按钮时,捕获事物的断点就在router.get()代码中。

在调试器中req.methodGET.

在浏览器(Chrome)中,我被告知我正在对/login返回的 302 进行 POST。还有一个 200 代码的GET待处理。/login这两个代码(302、200)是调试器在router.get(). 即使清除浏览器缓存也无济于事。

有人能告诉我为什么我的POST要求没有得到尊重吗?

4

2 回答 2

1

简单的答案

POST /login变成的原因GET /login 302是护照模块完成的重定向。

请参阅failureRedirect以下代码:

router.post('/login', passport.authenticate('local-login', {
    successRedirect: '/welcome',
    failureRedirect: '/login',
    failureFlash : true
}));

当提供的凭据无效或服务器因任何原因无法进行身份验证时,可能会发生这种情况。

乐于助人!

于 2017-02-11T15:25:01.153 回答
0

看起来该策略locallocal-login符合此文档

看起来passport.use函数的第一个参数应该是 LocalStrategy 对象,而不是字符串。

试试看!

于 2015-02-19T17:28:43.217 回答