ExpressJS - 会话

HTTP 是无状态的;为了将一个请求与任何其他请求关联起来,您需要一种在 HTTP 请求之间存储用户数据的方法。Cookie 和 URL 参数都是在客户端和服务器之间传输数据的合适方式。但它们都是可读的,并且位于客户端。会话正好解决了这个问题。您为客户端分配一个 ID,然后客户端使用该 ID 发出所有进一步的请求。与客户端相关的信息存储在与此 ID 关联的服务器上。

我们将需要 Express-session,因此请使用以下代码安装它。

npm install --save express-session

我们将把 sessioncookie-parser 中间件放到位。在此示例中,我们将使用默认存储来存储会话,即 MemoryStore。切勿在生产环境中使用它。会话中间件会为我们处理所有事情,即创建会话、设置会话 cookie 以及在 req 对象中创建会话对象。

每当我们再次从同一客户端发出请求时,我们都会将其会话信息存储在我们这里(假设服务器未重新启动)。我们可以向会话对象添加更多属性。在下面的示例中,我们将为客户端创建一个查看计数器。

var express = require('express');
var cookieParser = require('cookie-parser');
var session = require('express-session');

var app = express();

app.use(cookieParser());
app.use(session({secret: "Shh, its a secret!"}));

app.get('/', function(req, res){
   if(req.session.page_views){
      req.session.page_views++;
      res.send("You visited this page " + req.session.page_views + " times");
   } else {
      req.session.page_views = 1;
      res.send("Welcome to this page for the first time!");
   }
});
app.listen(3000);

上述代码的作用是,当用户访问网站时,它会为用户创建一个新会话并为其分配一个 cookie。下次用户访问时,将检查 cookie,并相应地更新 page_view 会话变量。

现在,如果您运行应用程序并转到 localhost:3000,将显示以下输出。

首次访问

如果您重新访问该页面,页面计数器将增加。以下屏幕截图中的页面刷新了 42 次。

首次访问