客户端和服务端登录状态的保存cookie、session、redis ——nodejs

用户登录的状态如何保存?如何方便的保存?如何安全的保存?

背景

项目中的登录功能必不可少,登录之后状态是怎么保存的呢,客户端是如何知道我们登录了没有呢?

由于本人是前端开发,所以对这块不太了解,学习时记录一下,加深理解...

客户端保存登录状态

客户端保存登录状态一般是用cookiecookie是客户端和服务端都能操作的,在用户登录成功之后,可以在服务端写入cookie,在nodejs中如下:

javascript 复制代码
 //nodejs  
 // 获取 cookie 的过期时间
    const getCookieExpires = () => {
      const d = new Date()
      d.setTime(d.getTime() + (24 * 60 * 60 * 1000))
      console.log('d.toGMTString() is ', d.toGMTString())
      return d.toGMTString()
    }
    

// 限制前台修改cookies httpOnly
// 限制过期时间 expires=${getCookieExpires()
    res.setHeader("Set-Cookie",`userId=${req.userId};path=/;httpOnly; expires=${getCookieExpires()}`)
 

因为浏览器是可以直接修改cookie的,所以要加上httpOnly限制。

客户端用cookie保存的缺点:

  • cookie暴露很危险,任何人都能看到
  • 没加httpOnly限制的话可以随意更改

所以,为了解决这个问题,我们用服务端来存储关键信息

服务端保存登录状态

那么服务端存储我们自然想到可以使用session来存储。怎么把客户端和用户信息对应起来呢?

我们不是就完全放弃cookie了,我们还是要用cookieseesion配合起来:

既然cookie不能存储关键隐私信息,那么我们就存一个无关紧要的唯一标识就行了,然后拿这个标识与用户信息的session建立映射关系,当用户请求携带了这个cookie,我们去session中找到对应的用户信息就可以了

在nodejs中:

然后再登录成功的逻辑中,把用户信息存进去就行了。

这样我们就可以安全的保存我们的用户信息了。

但是...

凡事都有但是...这样做还不行,安全是安全了,但是用起来不方便,怎么不方便呢?

session的问题 session是js 变量,放在nodejs进程内存中。

  • 第一,进程内存有限,访问量过大,内存暴增怎么办?

  • 第二,正式上线是多进程,进程之间无法共享。现在企业都是在一台机器上跑多个node进程来提升效率和使用率,但是每个进程的内存是相互隔离的,所以登录状态没法共享

  • 第三 , session会在服务端关闭时释放存储空间,但服务端每次更新都要重启,或者运维同学运维也要重启,导致频繁的需要用户登录体验不好

怎么解决这个问题?方案:redis

  • 第一: redis集群可以突破内存限制
  • 第二: 只要redis不重启数据就不会消失
  • 第三: 存在redis的数据每个node进程都可以访问
  • 第四: redis性能好速度快

我们在登录完成之后,把用户的信息放在redis里面,获取的时候也从里面获取。

这样就可以放心的使用用户信息了。

具体逻辑感兴趣的可以看看源码

相关推荐
sxgzzn5 小时前
能源行业智能监测产品与技术架构解析
架构·数字孪生·无人机巡检
小邓吖5 小时前
自己做了一个工具网站
前端·分布式·后端·中间件·架构·golang
Java烘焙师7 小时前
架构师必备:灰度方案汇总
架构·数仓
王锋(oxwangfeng)8 小时前
企业出海网络架构与数据安全方案
网络·架构·自动驾驶
麦聪聊数据9 小时前
利用SQL2API模式重构微服务中的数据查询层
数据库·sql·低代码·微服务·架构
郝学胜-神的一滴10 小时前
Python List操作:+、+=、extend的深度解析
开发语言·数据结构·python·程序人生·架构·list
小北的AI科技分享10 小时前
GPU并行计算架构在AI与科学计算中的性能优势
架构··
九皇叔叔11 小时前
【03】微服务系列 之Nacos 注册中心(服务注册)
java·微服务·nacos·架构·注册中心·服务注册
国科安芯11 小时前
航空级PMSM驱动系统中MCU的故障诊断与容错控制策略研究
单片机·嵌入式硬件·安全·架构·制造·安全性测试
Prince-Peng11 小时前
技术架构系列 - 详解Redis
数据结构·数据库·redis·分布式·缓存·中间件·架构