我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Node.js编程中客户端Session的使用详解

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Node.js编程中客户端Session的使用详解

静态网站很容易扩展。你只需要全部缓存,不需要考虑从不同服务器组合有状态的内容给用户。

可惜,大多数Web应用使用有状态的内容提供个性化体验。如果你的应用可以登录,就需要记住用户的Session。经典的处理方法是客户端设置包含随机唯一Session标识的Cookie,被标识的Session数据保存到服务端。


扩展有状态服务

当扩展服务的时候,你肯定有三种选择:

不同服务端同步Session数据 不同服务端连接单点中心(获取Session) 保证用户访问同一个服务端

但都有缺陷:

同步数据增加性能开销 单点中心降低系统扩展性 如果用户上次访问的服务端需要维护怎么办

然而,如果你换个角度思考,会发现第四种选择:将Session数据保存在客户端


客户端Session

在客户端保存Session有一些优势:

无所谓哪个服务端,Session数据都有效 不需要维护服务端状态 不需要服务端同步 任意添加新的服务端

但是客户端Session存在一个严重问题:你不能保证用户不篡改Session数据。


比如你在Cookie中保存用户的ID。用户很容易修改它,从而访问别人的账户。

这似乎否定了客户端Session的可能,但有一种方法可以巧妙解决这问题:加密打包Session数据(还是存在Cookie中)。这样就不需要担心用户修改Session数据,服务端会验证数据的。

实际应用上,就是Cookie中保存一个加密的Server Key。Server Key验证后才有权利读取和修改Session数据。这就是客户端Session。


Node客户端Session

Node.JS有一个库可以实现客户端Session:node-client-session.它可以代替Connect(一个Node中间件框架)内置的session和cookieParser中间件。

在Express框架应用中的使用:


const clientSessions = require("client-sessions"); 

app.use(clientSessions({ secret: '0GBlJZ9EKBt2Zbi2flRPvztczCewBxXK' // 设置一个随机长字符串! })

然后,向req.session对象添加属性:


app.get('/login', function (req, res){ req.session.username = 'JohnDoe'; });

读取属性:


app.get('/', function (req, res){ res.send('Welcome ' + req.session.username); });

使用reset方法终止Session:


app.get('/logout', function (req, res) { req.session.reset(); });

即时注销Persona Session

(注:Persona是Mozzilla推出的网络身份系统)

与服务器端Session不同,客户端Session的问题是服务端无法删除Session。

服务器端架构时,你可以删除Session数据。任意的客户端Cookie标识的Session很可能不存在。但客户端架构时,Session数据不在服务端,不能保证Session数据在每个客户端都被删除。换句话说,我们无法同步用户的客户端状态(已经登录)和服务端状态(注销登录)。

为了弥补这个缺陷,客户端Session中添加了过期时间。展开Session数据(被加密打包)前验证过期时间。如果过期了,抛弃Session数据并改变用户状态(如注销登录)。

过期机制在很多应用中运行良好(尤其是短过期时间需求)。如在Persona中,当用户发觉密码收到威胁或已经损坏时,我们需要提供方法让用户立即注销Session数据。

这意味着需要保留一点点状态信息在服务后端。我们处理即时注销的方法是添加一个Token在用户数据表和Session数据中。


每次API调用时比对Session数据中的Token和数据库中的Token。如果不相同,返回错误信息并退出用户。

这样会附加多余的数据库操作去查询Token。幸好,大多数的API调用都需要读取用户数据表,把Token一起带上就好了。


免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Node.js编程中客户端Session的使用详解

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Node.js编程中客户端Session的使用详解

静态网站很容易扩展。你只需要全部缓存,不需要考虑从不同服务器组合有状态的内容给用户。 可惜,大多数Web应用使用有状态的内容提供个性化体验。如果你的应用可以登录,就需要记住用户的Session。经典的处理方法是客户端设置包含随机唯一Sess
2022-06-04

Session对象失效的客户端解决方法284627详解

这篇文章主要介绍了Session对象失效的客户端解决方法,需要的朋友可以参考下
2023-05-20

Session对象失效的客户端解决方法284567详解

这篇文章主要介绍了Session对象失效的客户端解决方法,需要的朋友可以参考下
2023-05-20

node.js 中间件express-session使用详解

本文介绍的关于node.js中间件express-session的相关内容,分享出来供大家从参考学习,下面来一起看看详细的介绍: 一、为什么使用session? session运行在服务器端,当客户端第一次访问服务器时,可以将客户的登录信息
2022-06-04

Linux中编译安装Subversion客户端的教程

这篇文章主要讲解了“Linux中编译安装Subversion客户端的教程”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Linux中编译安装Subversion客户端的教程”吧!Subvers
2023-06-13

Java中怎么利用HBase实现客户端编程

这篇文章将为大家详细讲解有关Java中怎么利用HBase实现客户端编程,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。1. 准备工作下载后安装jdk包(这里使用的是jdk-6u10-rc2-b
2023-06-17

MySQL中mysqladmin客户端的使用方法

小编给大家分享一下MySQL中mysqladmin客户端的使用方法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧! mysqladmin是MySQL官方提供
2023-06-14

使用.NETMAUI开发ChatGPT客户端的流程

最近 chatgpt 很火,由于网页版本限制了ip,还得必须开代理,用起来比较麻烦,所以我尝试用maui开发一个聊天小应用,结合chatgpt的开放api来实现,这篇文章主要介绍了使用.NETMAUI开发ChatGPT客户端,需要的朋友可以参考下
2022-12-21

telenet客户端的使用及win10系统安装不了telenet客户端的解决方法

  Telnet?这个服务是什么功能呢?我们不仅这样问。那么对于Telnet客户端的一些内容,希望通过本文的讲解,能让大家对这个协议有所了解。  Telnet是基于征求意见文档 (RFC) 854 的标准 Internet 程序和协议。该 RFC 指定在网络中传输和接收未加密 ASCII 字符(纯文本)的方法。  Te
telenet客户端的使用及win10系统安装不了telenet客户端的解决方法
2024-04-18

详解如何使用Jersey客户端请求Spring Boot(RESTFul)服务

使用Jersey客户端请求Spring Boot服务可以通过以下步骤实现:1. 添加Jersey依赖:在你的项目中添加Jersey依赖。可以通过Maven或者Gradle添加以下依赖:```xmlorg.glassfish.jersey.c
2023-08-17

Node.js中的事件驱动编程详解

在传统程编程模里,I/O操作就像一个普通的本地函数调用:在函数执行完之前程序被堵塞,无法继续运行。堵塞I/O起源于早先的时间片模型,这种模型下每个进程就像一个独立的人,目的是将每个人区分开,而且每个人在同一时刻通常只能做一件事,必须等待前面
2022-06-04

FileZilla客户端的安装配置教程以及使用教程(超级详细)

一、 下载FileZilla客户端 FileZilla客户端官网下载地址:https://filezilla-project.org/download.php?type=client 1. 点击“Download FileZilla Cli
2023-08-24

python中session的使用案例详解

这篇文章主要介绍了python session使用,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
2023-05-19

node.js中的require使用详解

代码注释里已经描述的非常的清晰,这里就不多废话了,直接奉上代码:/*在node中,可以使用require()函数来加载模块.* require函数使用一个参数,参数值可以带有完整路径的模块的文件名,也可以为模块名.当使用node中提供的模块
2022-06-04

在MySQL中,为什么一个客户端不能使用另一个客户端定义的用户定义变量?

在 MySQL 中,一个客户端定义的用户定义变量不能被另一个客户端看到或使用,因为用户定义变量是特定于连接的。这意味着当客户端退出时,给定客户端连接的所有变量都会自动释放
2023-10-22

在MySQL中,为什么一个客户端不能使用另一个客户端定义的用户定义变量

在MySQL中,每个客户端都有自己的会话空间,用于存储会话变量和用户定义变量。每个客户端之间的会话空间是相互隔离的,因此一个客户端无法直接访问另一个客户端定义的变量。当一个客户端定义一个用户定义变量时,它只能在该客户端的会话中使用和访问这个
2023-10-20

Node.js使用Middleware中间件教程详解

中间件(Middleware),特指业务流程的中间处理环节,Express中间件的调用流程-当一个请求处理时,可以连续调用多个中间件,从而对这次请求进行预处理
2023-05-15

编程热搜

目录