我有以下内容:
import {Router} from 'express';
import passport from 'passport';
import {Strategy} from 'passport-local';
import pg from 'pg';
import {pgUri} from '../environment';
let loginRouter = Router();
passport.use(new Strategy((username, password, done) => done(null, true)));
//{
// pg.connectAsync(pgUri)
// .then(([client, release]) => {
// return client.queryAsync('select * from users where "user" = $1::TEXT', [username])
// .finally(release);
// })
// .tap(result => console.log(result.rows))
// .then(result => done(null, true));
//}));
loginRouter.get('/', (request, response) => response.render('login'));
loginRouter.post('/', passport.authenticate('local', {successRedirect: '/',
failureRedirect: '/login'}));
export default loginRouter;
这是一个快速路由文件,它定义了最简单的身份验证方案。以上总是重定向回/login
,表示失败。
我试过的
- 更改
failureRedirect
为/loginFailed
真正重定向到那里。所以登录确实失败。 console.log
函数体内的断点和s 不会被命中。- 调用
done
withdone(null, {foo: "bar"})
而不是 true 不会改变任何事情。
值得注意
- 我正在使用 babel 来支持 ES6,但由于这是唯一失败的部分,而且我可以设置的断点(之前
passport.use
)显示所有变量的预期值,我认为这不是问题所在。 - 路线
.get()
按预期工作,显示表单。
我在引导阶段有这个:
app.use(session({
secret: "some-secret",
resave: true,
saveUninitialized: true
}));
app.use(passport.initialize());
app.use(passport.session());
passport.serializeUser((user, done) => done(null, {foo: "bar"}));
passport.deserializeUser((user, done) => done(null, {foo: "bar"}));
这是我正在使用的表格(直接从护照示例中复制)
<form action="/login" method="post">
<div>
<label>Username:</label>
<input type="text" name="username"/>
</div>
<div>
<label>Password:</label>
<input type="password" name="password"/>
</div>
<div>
<input type="submit" value="Log In"/>
</div>
</form>
我不知道这里出了什么问题。将不胜感激任何帮助。