- ExpressJS 教程
- ExpressJS - 主页
- ExpressJS - 概述
- ExpressJS - 环境
- ExpressJS - 你好世界
- ExpressJS - 路由
- ExpressJS - HTTP 方法
- ExpressJS - URL 构建
- ExpressJS - 中间件
- ExpressJS - 模板
- ExpressJS - 静态文件
- ExpressJS - 表单数据
- ExpressJS - 数据库
- ExpressJS - Cookie
- ExpressJS - 会话
- ExpressJS - 身份验证
- ExpressJS - RESTful API
- ExpressJS - 脚手架
- ExpressJS - 错误处理
- ExpressJS - 调试
- ExpressJS - 最佳实践
- ExpressJS - 资源
- ExpressJS 有用资源
- ExpressJS - 快速指南
- ExpressJS - 有用的资源
- ExpressJS - 讨论
ExpressJS - 会话
HTTP 是无状态的;为了将一个请求与任何其他请求相关联,您需要一种在 HTTP 请求之间存储用户数据的方法。Cookie 和 URL 参数都是在客户端和服务器之间传输数据的合适方法。但它们都是可读的并且位于客户端。Session 正好解决了这个问题。您为客户端分配一个 ID,它会使用该 ID 发出所有进一步的请求。与客户端关联的信息存储在与该 ID 链接的服务器上。
我们需要Express-session,因此使用以下代码安装它。
npm install --save express-session
我们将放置会话和cookie 解析器中间件。在本例中,我们将使用默认存储来存储会话,即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次。