我正在尝试构建一个快速应用程序,但现在我陷入了登录过程。我不确定它与我所遇到的问题有什么关系,但我对学校的支持表示我必须使用passport.js来登录表格。
所以,我遇到的问题是,每当我尝试在浏览器上使用localhost:3000 / login渲染我的页面时,我收到此消息:
CANNOT GET /login
我的代码可能存在更多问题,但由于我已经收到此错误,因此无法找到。
我的默认应用文件:
const express = require('express');
const app = express();
app.listen(3000, () => {
console.log('Example listening on port 3000!')
});
const loginRoute = require('./routes/logins.js');
app.use('/login', loginRoute);
const passport = require('passport')
, LocalStrategy = require('passport-local').Strategy;
passport.use(new LocalStrategy(
function(username, password, done) {
User.findOne({ username: username }, function(err, user) {
if (err) { return done(err); }
if (!user) {
return done(null, false, { message: 'Incorrect username.' });
}
if (!user.validPassword(password)) {
return done(null, false, { message: 'Incorrect password.' });
}
return done(null, user);
});
}
));
module.exports = app;
我的路线/登录档案:
const express = require('express');
const router = express.Router();
const pug = require('pug');
const login = pug.compileFile('views/login.pug');
router.get('/login', function(req, res, next) {
res.render('login', { title: 'Login' });
});
const passport = require('passport');
router.post('/login',
passport.authenticate('local', { successRedirect: '/',
failureRedirect: '/login',
failureFlash: true })
);
module.exports = router;
我的观点/ login.pug文件:
doctype html
html
head
body
h1 #{title}
form(action='/login', method='post')
div
label Username:
input(type='text', name='username')
div
label Password:
input(type='password', name='password')
div
input(type='submit', value='Log In')
如果有人可以帮助我,我会非常感激。
答案 0 :(得分:1)
因为您正在将路由器安装到路径/login
上,然后在路由器中安装:
router.get('/login', function(req, res){...})
Express会将其评估为localhost:3000/login/login
路由器文件中的路径应该与您安装它的路径相关。因此,对于localhost:3000/login
,您的logins
路由器应该如下所示
router.get('/', function(req, res){...})
//and
router.post('/', function(req, res){...})