12

我在登录功能中这样做

app.post('/teacherlogin', function(request, response) {
    var username = request.body.username;
    var password = request.body.password;
    con.query('SELECT t_id from login_teacher where username="'+username+'" and password="'+password+'"',function(err,results){

       if(results.length > 0) {

           request.session.regenerate(function(){
              request.session.user = username;
              request.session.type = 'teacher';
              request.session.id = results[0].t_id;
              response.redirect('/teacherhome');
          });

       } else {

          response.redirect('teacherlogin');
       }

    });

});

现在我想发出存储到会话对象的“id”和“type”。我该怎么做?我已经阅读了这篇文章,但由于缺乏经验,我在使用它时遇到了困难。我在我的代码中使用了它

var MemoryStore = express.session.MemoryStore;
var sessionStore = new MemoryStore();
app.use(express.bodyParser());
app.use(express.cookieParser('secret text'));
app.use(express.session({
    store: sessionStore,
    secret: 'secret', 
    key: 'express.sid'}
));

var Session = require('connect').middleware.session.Session;
io.set('authorization', function (data, accept) {
    if (data.headers.cookie) {
        data.cookie = require('cookie').parse(data.headers.cookie);
        data.sessionID = data.cookie['express.sid'].split('.')[0];
        console.log('data.sessionID "'+data.sessionID);
        data.sessionStore = sessionStore;
        sessionStore.get(data.sessionID, function (err, session) {
           if (err || !session) {
               accept('Error', false);
           } else {
               data.session = new Session(data, session);
               accept(null, true);
           }
        });
    } else {
      return accept('No cookie transmitted.', false);
    }
});

我在会话对象中没有得到任何东西。我试图记录 sessionStore 的内容,它似乎是空的!这是否意味着我存储在会话中的信息没有存储在 sessionStore 中?如果是,我应该怎么做才能将其存储在那里?如果它存储在那里,为什么 sessionStore.get 函数找不到它?

4

2 回答 2

9

我不确定您是否仍在处理此问题,但您可以仅使用 MemoryStore 访问会话数据。毕竟,如果它不起作用,Express 还能如何使用它?:)

演示 MemoryStore 工作的一个简单方法是:

var express = require("express")
  , app = express()
  , sessionStore = new express.session.MemoryStore();

// middleware
app.use(express.cookieParser());
app.use(express.session({store: sessionStore, secret: "mysecret"}));

// any endpoint sets a cookie
app.get("/", function(req,res) {
  res.send('ok');
});

// This endpoint reveals it
app.get("/session", function(req, res){
  sessionStore.get(req.sessionID, function(err, data) {
    res.send({err: err, data:data});
  });
});

app.listen(3000);

击中/后跟/session会导致以下响应:

{
  "err": null,
  "data": {
    "cookie": {
      "originalMaxAge": null,
      "expires": null,
      "httpOnly": true,
      "path": "/"
    }
  }
}

我怀疑您的问题可能是您如何从套接字获取 sessionID,但绝对可以从 MemoryStore 中提取会话。另外,请记住重新启动 Express 服务器会破坏所有会话,因此每次重新启动后都需要一个新的 cookie。

于 2014-02-10T06:01:53.850 回答
0

您必须使用数据库来存储您的快速会话,然后解析 socket.io 定义中的 cookie 数据,并使用获得的信息从数据库中获取会话信息,这是一个完整的示例:

https://stackoverflow.com/a/13098742/218418

您还可以使用从 cookie 中解析的会话 ID,并将用户加入带有会话名称的“聊天室”。

于 2013-11-12T08:13:01.510 回答