两台服务器上的快速会话

Express-session on two servers

我一直在尝试在 两个 本地服务器上使用 express-session。

第一个服务器用于操作数据库,第二个用于加载页面。 我想在第一个服务器的会话中保存一些数据并在第二个服务器中使用它。

这是第一个API

的代码
require("dotenv").config();

const express = require('express');
const mysql = require("mysql");
const crypto = require("crypto");
const cors = require("cors");

const apiApp = express();

apiApp.use(express.json());
apiApp.use(cors());

const pool = mysql.createPool({
  user: process.env.DB_USER,
  password: process.env.DB_PASS,
  database: process.env.DB_NAME,
  host: "localhost"
});

var algorithm = 'aes256'; // algorithm
var key = 'password';

apiApp.post('/api/Connexion', (req, res) => {

  let cipheriv = crypto.createCipher(algorithm, key);  
  let encryptedPassword = cipheriv.update(req.body.motDePasse, 'utf8', 'hex') + cipheriv.final('hex');

  var data = [req.body.courriel, encryptedPassword];

  const query = "SELECT * FROM utilisateurs WHERE courriel=? AND motDePasse=?";
  pool.query(query, data, (error, results) => {
    if (results[0] && !error) {
      res.send(true);
      req.session.courriel = req.body.courriel;
    } else {
      res.send(false);
    }
  });
});

module.exports = apiApp;

第二个

require("dotenv").config();

const express = require('express');
const cors = require("cors");
const path = require("path");

const coreApp = express();

coreApp.use(express.json());
coreApp.use(cors());

let dir = path.resolve(__dirname, '..', '..') + '/'
coreApp.use(express.static(dir));

coreApp.get('/connexion', (req, res) => {
    if (req.session != undefined) {
        console.log(req.session.courriel);
    }
    res.sendFile(dir + "index.html");
});

coreApp.get('/application', (req, res) => {
    res.sendFile(dir + "application.html");
});

coreApp.get('/:a', (req, res) => {
    res.redirect("/");
});

module.exports = coreApp;

所以,我试图在第一个代码的 行 64 设置会话变量,并在第一个代码的 行 17 使用它第二个代码。

我该怎么做? 谢谢!

如果您使用共享数据库作为快速会话的会话存储(通常是 Redis),则可以在服务器之间共享会话数据,但是只要两个服务器访问同一个数据库以进行快速会话存储,任何数据库都可以工作,并且快速会话配置正确。

express-session storage providers for dozens of databases, including express-mysql-session 可以与您正在使用的数据库一起使用。