如何在登录事件后使nodejs Express会话中的userid持续存在?

时间:2018-10-08 12:45:00

标签: node.js express socket.io

会话用户标识不可用,因为在express nodejs中刷新了会话。即使在刷新网页后重新出现。我正在使用快速会话。

我正在通过这样的外部URL访问我的nodejs套接字应用程序-

socket = io.connect('https://xxx.xxx.net:3000/')
var uid = app.user.get('id');                    
socket.emit("login_register", { user: uid });

服务器文件代码-

var crypto = require('crypto')
const http = require('https')
const express = require('express')
const cookieParser = require('cookie-parser')
const mysql = require('mysql')
const socket = require('./socket')
const routes = require('./routes')
var bodyParser = require('body-parser');
const { sessionMiddleware } = require('./middlewares')

var app = express();  
const server = http.createServer(options,app)
const io = socket(server)

io.use((socket, next) => {
  sessionMiddleware(
    socket.request,
    socket.request.res,
    next
  ) 
})

app.use(sessionMiddleware)

app.use(express.static('public'))
app.use('/', routes)
app.use(cookieParser())

// parse application/x-www-form-urlencoded
app.use(bodyParser.urlencoded({ extended: false }))

app.use(function(req, res, next) {
  res.header("Access-Control-Allow-Origin", "*");
  res.header("Access-Control-Allow-Headers", "Origin, X-Requested-With, 
   Content-Type, Accept");
   next();
 });

  io.on('connection', socket => {

    console.log('in on');
    const req = socket.request

    socket.on("login_register", function (data) {
      x = JSON.stringify(data);
      console.log('login-- '+x);        
      const { user } = data     
      req.pass = user
      req.session.userID = user
      console.log('loginuser-' + req.session.userID)        
      console.log('sessionTD-'+socket.request.sessionID);
      console.log(socket.request.session);      
      req.session.save();   

}); 

控制台日志数据-

 in on
 sessionTD-gp0cmPbWlWrwVuMlb3wlFwEJayhNRy7D
 undefined
 login-- {"user":"121"}
 loginuser-121
 sessionTD-gp0cmPbWlWrwVuMlb3wlFwEJayhNRy7D
 Session {
  cookie:
    { path: '/',
     _expires: null,
     originalMaxAge: null,
     httpOnly: true },
     userID: '121' }
 in on
  sessionTD-Xwoa0U8QWB0d6rpuksEYWFS4rRgCTcA6
  undefined
  sessionTD-Xwoa0U8QWB0d6rpuksEYWFS4rRgCTcA6
  Session {
   cookie:
     { path: '/',
        _expires: null,
        originalMaxAge: null,
        httpOnly: true } }

第一个会话具有用户ID,但立即丢失。如果刷新网页,它将再次出现。 sessionmiddleware具有将中间件文件中定义的快速会话另存为的代码-

 const session = require('express-session')
 const sessionMiddleware = session({
    secret: 'secret123',
    resave: true,
    saveUninitialized: true 
 })

谁能在第一时间帮助您保存它。

0 个答案:

没有答案