- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我目前正在使用在线教程运行一个简单的测试 MEAN 堆栈:
这是应用程序文件:
app.js
var express = require("express");
var mongoose = require("mongoose");
var path = require("path");
var bodyParser = require("body-parser");
var cookieParser = require("cookie-parser");
var session = require("express-session");
var flash = require("connect-flash");
var ejs = require("ejs");
var routes = require("./routes");
var app = express();
mongoose.connect("mongodb://localhost:27017/testdb");
app.set("port", process.env.PORT || 3000);
app.set("views", path.join(__dirname, "views"));
app.set("view engine", "ejs");
app.use(bodyParser.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(session({
secret: "secret",
resave: true,
saveUninitialized: true
}));
app.use(flash());
app.use(routes);
app.listen(app.get("port"), function() {
console.log("MEAN social media server started on port " + app.get("port"));
});
虽然这个app.js 文件中有 View ,但这里的重点是routes 变量所需的路由:
routes.js
var express = require("express");
var passport = require("passport");
var User = require("./models/user");
var router = express.Router();
router.use(function(req, res, next) {
res.locals.currentUser = req.user;
res.locals.errors = req.flash("error");
res.locals.infos = req.flash("info");
next();
});
router.get("/", function(req, res,next) {
User.find()
.sort({ createdAt: "descending" })
.exec(function(err, users) {
if (err) {
return next(err);
}
res.render("index", { users: users });
});
});
router.get("/signup", function(req, res) {
res.render("signup");
});
router.post("/signup", function(req, res, next) {
var username = req.body.username;
var password = req.body.password;
User.findOne({ username: username }, function(err, user) {
if (err) {
return next(err);
}
if (user) {
req.flash("error", "User already exists");
return res.redirect("/signup");
}
var newUser = new User({
username: username,
password: password
});
newUser.save(next);
});
}, passport.authenticate("login", {
successRedirect: "/",
failureRedirect: "/signup",
failureFlash: true
}));
router.get("/users/:username", function(req, res, next) {
User.findOne({ username: req.params.username }, function(err, user) {
if (err) {
return next(err);
}
if (!user) {
return next(404);
}
res.render("profile", {
user: user
});
});
});
module.exports = router;
这是 views/signup.ejs 文件:
views/signup.ejs
<% include _header %>
<h1>Sign up</h1>
<form action="/signup" method="post">
<input name="username" type="text" class="form-control" placeholder="Username" required autofocus>
<input name="password" type="password" class="form-control" placeholder="Password" required>
<input type="submit" value="Sign up" class="btn btn-primary btn-block">
</form>
<% include _footer %>
当点击views/signup.ejs 文件的提交按钮时,'User' 记录确实被提交到 MongoDB 数据库,但是插入后在“/注册”发布方法:
localhost:3000/signup (POST)
Error: Unknown authentication strategy "login"
at attempt (/<APP_PATH>/node_modules/passport/lib/middleware/authenticate.js:166:37)
at authenticate (/<APP_PATH>/node_modules/passport/lib/middleware/authenticate.js:342:7)
at Layer.handle [as handle_request] (/<APP_PATH>/node_modules/express/lib/router/layer.js:95:5)
at next (/<APP_PATH>/node_modules/express/lib/router/route.js:131:13)
at model.<anonymous> (/<APP_PATH>/node_modules/mongoose/lib/document.js:1731:20)
at next_ (/<APP_PATH>/node_modules/hooks-fixed/hooks.js:89:34)
at fnWrapper (/<APP_PATH>/node_modules/hooks-fixed/hooks.js:186:18)
at /<APP_PATH>/node_modules/mongoose/lib/model.js:295:13
at /<APP_PATH>/node_modules/mongoose/lib/model.js:230:5
at /<APP_PATH>/node_modules/mongoose/lib/model.js:139:7
at /<APP_PATH>/node_modules/mongoose/node_modules/mongodb/lib/collection.js:479:5
at /<APP_PATH>/node_modules/mongoose/node_modules/mongodb/lib/collection.js:633:5
at /<APP_PATH>/node_modules/mongoose/node_modules/mongodb/lib/bulk/unordered.js:469:9
at resultHandler (/<APP_PATH>/node_modules/mongoose/node_modules/mongodb/lib/bulk/unordered.js:416:5)
at /<APP_PATH>/node_modules/mongoose/node_modules/mongodb-core/lib/topologies/server.js:778:13
at Callbacks.emit (/<APP_PATH>/node_modules/mongoose/node_modules/mongodb-core/lib/topologies/server.js:95:3)
我确实注意到 routes.js 中的 passport.authenticate 函数没有引用 "login" 事件文件。
有人收到类似的“错误:未知身份验证策略“登录””错误吗?
最佳答案
我会选择删除这个问题,但因为我真诚地熬夜解决这个问题,我至少应该发布错误是什么。
在构建此应用程序时,创建了以下 View :
如果您查看上面的 routes.js 文件,当有人发布注册表单时 (router.post("/signup"..), passport.authenticate 将发送用户自动注册“登录” View 并将用户发送到根端点。
调用的“登录”状态不存在导致错误,因此出现以下消息:
“错误:未知身份验证策略“登录””错误
谢谢大家的帮助。
关于javascript - express 和 Passport 错误 : Unknown authentication strategy "login",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40147267/
已经为此工作了几个小时,非常令人沮丧...... router.post('/', passport.authenticate('local-signup', function(err, user,
我正在寻找一种方法让我的客户端使用 facebook JS SDK 进行授权,然后以某种方式将此授权传输到我的 Node 服务器(以便它可以使用 fb graph api 验证请求) 我偶然发现: h
passport.socketio 抛出此错误,同时无法授权用户。 Error: Error: Failed to deserialize user out of session 我已将问题范围缩小到
passport.js 函数passport.serializeUser 和passport.serializeUser 有什么作用?这是维基百科中描述的序列化示例:http://en.wikiped
现代 Passport 和身份证的底部带有machine-readable zone (MRZ),其中包含基本标识信息(可能是OCR友好格式)。 机读区的格式指定了check digits的数量,可帮
我尝试对我的应用程序实现 passport 身份验证策略,但在尝试登录后不断收到以下错误: TypeError: passport.authenticate is not a function at
我正在将 passport 与 loopback 集成,并且工作正常,问题是如何获取访问 token 。 我有一个 web 应用程序(服务于与环回不同的服务器)所以: 发出请求(在环回后端) 这会将我
我使用带有passport-saml 策略 的 Passport 。在策略 上,有一个我想使用的函数。我知道策略是这样使用的: const SamlStrategy = require('passpo
这是我的套接字配置: // set authorization for socket.io io.set('authorization', passportSocketIo.authorize
我是 Passport.js 的新手。我一直在关注以下博客来注册用户 https://scotch.io/tutorials/easy-node-authentication-setup-and-lo
Passport 似乎是简单例份验证、不显眼且不难设置的绝佳选择。我正在构建一个使用 JWT 进行身份验证的 MEAN 堆栈,因此我查看了 Passport JWT。然而,有几件事我很困惑。 1) 假
我已经开始开发一个小项目,在客户端使用 React 和 Redux,后端是用 Node、Express 和 Passport.js 完成的我将尽力描述我几个小时以来所苦苦挣扎的事情。身份验证后,当用户
我正在使用 Passport 本地策略和 Passport Mongoose 本地来创建用户并检查用户身份验证。但是,我想探索使用电子邮件而不是用户名的选项。我按照文件的规定进行操作,但我未经授权。有
我正在使用 Passport 本地策略进行身份验证。在我的快速服务器中,我收到一个注册帖子请求,我应该为新用户将密码保存到数据库。但是我需要在保存到数据库之前对密码进行哈希处理。 但我不确定如何对其进
我正在将 node 与 express + mongoose 一起使用,并尝试将 passport.js 与 restful api 一起使用。 身份验证成功后,我不断收到此异常(我在浏览器上看到回调
我正在尝试在 JWTStrategy 中检查列入黑名单的 JWT token 。 jwtFromRequest 没有采用异步函数,所以我无法在那里检查它。 validate 函数提供对 JWT 负载而
目前,我正在通过 Google 构建登录功能,但我遇到了一些让我感到困惑的问题。 我们可以在一个项目中同时使用 Restful API 和 Graphql API 吗?除了谷歌身份验证,我们需要一些路
我正在使用与 express 配合良好的 Passport 本地策略: passport.use(localStrategy); passport.serializeUser((user, done)
我正在尝试通过passport-facebook 对用户进行身份验证,并且发生了一件非常奇怪的事情,我真的不确定。定义我的路线时,我有这行代码 app.get('/login/facebook',
当我使用 NPM 包“passport-azure-ad”尝试连接到 Azure AD 时,出现以下错误。我已成功连接到 Facebook、Google 和 MSFT Live,成功,但无法弄清楚为什
我是一名优秀的程序员,十分优秀!