2

在通过 MongoDB for 设置 sessionStore 时express-session,我在使用该findOne()函数来验证用户的信息是否有效且最新时遇到了一些麻烦。

var session = require('express-session');
var mongoStore = require('connect-mongo')(session);
var mongoose = require('mongoose');

var Schema = mongoose.Schema;
var Session = mongoose.model('session', new Schema({
    sid : String,
    username : String,
    email : String
}));

...

然而,诀窍在于它express-session负责connect-mongo管理对数据库的写入。

app.use(session({
    secret: 'secretsquirrel',
    resave: true,
    saveUninitialized: true,
    store: new mongoStore({
        mongoseConnection: mongoose.connection,
        host: '127.0.0.1',
        port: '27017',
        db: 'testdb',
        collection: 'collectionName'
    })
}));

现在,这似乎可以正常工作,因为文档已输入到我指定的集合中。从集合中返回数据会产生以下结果:

{  
   "_id":"sdBYsdflAsdfyWPPneV-hrC2xsXP",
   "session":"
   {
       \"cookie\":
       {
        \"originalMaxAge\":null,\"expires\":null,\"httpOnly\":true,\"path\":\"/\"
       },
       \"email\":\"testuser@email.com\",
       \"username\":\"testuser\",
       \"sid\":\"f59106e845e11df8c3413b5f1f80ee01e876526bc3c0d05\",
   }",
   "expires":   ISODate(DateHere)
}

如果问题出现在数据库中,或者通过 Mongoose,我尝试如何查询 SID 似乎并不重要,我使用以下任何方法都不返回任何结果:

通过蒙戈:

db.collectionName.findOne({ session.sid: "sid" })
db.collectionName.findOne({ "session.sid": "sid" })
db.collectionName.findOne({ "session": { "\"sid\"": "sid" } })

通过猫鼬(NodeJS)

Session.findOne({ sid: req.session.sid }, function(err, data) {...});
Session.findOne({ "sid": req.session.sid }, function(err, data) {...});
Session.findOne({ "\"sid"\"": "\"" + req.session.sid + "\"" }, function(err, data) {...});

问题是,在这两种情况下我都无法返回任何我已经验证在集合中的数据是怎么回事?我是否需要像我一直在尝试做的那样考虑文档中返回的转义引号,还是仅仅通过 mongo shell 输出?

我是否缺少正确搜索此数据的任何步骤?一组新鲜的眼睛将不胜感激!

解决方案:

vinagreti指出,保存到我的集合中的数据不是对象,而是纯文本。

通过参考connect-mongo 的文档,有一个额外的选项stringify. 此设置字符串化并将会话保存的数据序列化到数据库中。考虑到这express-session已经产生了一个 JSON 对象,使用stringify()使得它在集合中不可搜索。

所需要的只是添加stringify: false到我的 mongoStore 设置中,如下所示:

store: new mongoStore({
        mongoseConnection: mongoose.connection,
        host: '127.0.0.1',
        port: '27017',
        db: 'testdb',
        collection: 'collectionName',
        stringify: false
    })

然后瞧!保存到集合中的所有内容现在都是对象并且可以搜索!感谢vinagreti帮助指出问题!请点赞他的回答!

4

1 回答 1

4

您将会话对象保存为纯文本。因此,您无法作为对象进行搜索。

确保“父亲”集合的架构具有类型为“{}”(对象)的会话字段,例如:Father = {session: { type: {} }}

如果它不起作用,您可以尝试以下方法:

您可以更改保存会话对象的方式,将其保存为对象而不是纯文本。

或者,您可以使用正则表达式搜索会话,尝试在会话字段中查找sid ,例如:

db.user.findOne({session: /.*f59106e845e11df8c3413b5f1f80ee01e876526bc3c0d05.*/});
于 2015-06-12T19:17:32.063 回答