最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

Node中使用MemoryStore存储session数据,类似于PHP中的$

网站源码admin34浏览0评论

Node中使用MemoryStore存储session数据,类似于PHP中的$

Node中使用MemoryStore存储session数据,类似于PHP中的$

问题:

是否可以在php中存储类似于$_SESSION['somedata'] = "Hello"的session数据?

到目前为止,这是我的代码:

创建内存存储

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

快速配置

app.configure(function(){
  app.set('views', __dirname + '/views');
  app.set('view engine', 'jade');
  app.use(express.bodyParser());
  app.use(express.methodOverride());
  app.use(express.cookieParser());
  app.use(express.session({
    store: sessionStore,
    secret: 'secret', 
    key: 'express.sid'}));
  app.use(require('stylus').middleware({src: __dirname + '/public'}));
  app.use(app.router);
  app.use(express.static(__dirname + '/public'));
});

解析cookie以获取握手授权的会话ID

var parseCookie = require('connect').utils.parseCookie;

io.set('authorization', function (data, accept) {
  if (data.headers.cookie) {
    data.cookie = parseCookie(data.headers.cookie);
    data.sessionID = data.cookie['express.sid'];

    sessionStore.get(data.sessionID, function (err, session) {
      if (err) 
      {
          accept(err.message, false); //Turn down the connection
      } 
      else
      {
          data.session = session; //Accept the session
          accept(null, true);
      }
    });
  } else {
     return accept('No cookie transmitted.', false);
  }
});

当密码和用户名是“admin”时存储“loggedin”

io.sockets.on('connection', function (socket) {

  socket.on('details', function(data){
    console.log("Details: " + data.u + data.p);
    if(data.p == "admin" && data.u == "admin")
    {
      //Add the logged in field to the session
    }
  });
});

如果用户已登录,将他们重定向到主页

app.get(navigation.login.uri, function(req, res){
  if(req.session.loggedin)
  {
    res.redirect('/home');
  }
  else
  {
    res.render('login', {
      title: navigation.login.title,
      navigation: navigation
    });
  }
});

当我尝试使用时:

req.session.loggedIn

该值未定义。这可能是存储问题,还是我访问不正确?

回答如下:

你很接近 - 只是缺少一些东西。

您在套接字授权功能中收集的信息可通过连接处理程序中的 socket.handshake 访问。

所以,我想你想要的是:

io.sockets.on('connection', function (socket) {

  socket.on('details', function(data){
    console.log("Details: " + data.u + data.p);
    if(data.p == "admin" && data.u == "admin")
    {
      //Add the logged in field to the session
      socket.handshake.session.loggedIn = true;  // Set the new session var
      socket.handshake.session.save();           // Save the modified session
    }
  });
});

修改后不要忘记保存会话,否则它永远不会回到商店中。

发布评论

评论列表(0)

  1. 暂无评论