Redis的实战常用一、验证码登录(解决session共享问题)(思路、意识)

news2025/2/8 13:46:03

一、基于session实现登录功能

  • 第一步:发送验证码:

    • 用户在提交手机号后,会校验手机号是否合法:
      • 如果不合法,则要求用户重新输入手机号
      • 如果手机号合法,后台此时生成对应的验证码,同时将验证码进行保存(存到session里面),然后再通过短信的方式将验证码发送给用户
  • 第二步:短信验证码登录、注册:

    • 用户输入刚刚获取到的验证码,而后台则从session中拿到当前验证码,然后和用户输入的验证码进行校验
      • 如果不一致,则无法通过校验(提示验证码错误)
      • 如果一致,则后台根据手机号查询用户:
        • 如果用户不存在,则为用户创建账号信息,保存到数据库,再将用户信息保存到session中
        • 如果存在,则直接存入到session中取。
      • 无论是否存在,都会将用户信息(这个用户信息可以创建个UserDTO对象,把想要暴露的信息存储到session中去,这样就可以减少数据暴露的风险)保存到session中,方便后续获得当前登录信息。
  • 第三步:校验登录状态(登录时的逻辑):

    • 用户在请求登录的时候,会从cookie中携带者JsessionId到后台,后台通过JsessionId从session中拿到用户信息
      • 如果没有session信息,则进行拦截,无法进行登录。
      • 如果有session信息,则将用户信息保存到threadLocal中,并且放行。
  • 使用拦截器:当每个业务都需要进行用户信息的验证时,不可能每个业务都写一次登录校验的逻辑,这就需要使用到拦截器了(拦截器是在所有的业务执行之前执行的)。我们把这个登录校验的逻辑写到拦截器里面去,这样每次用户无论访问哪个业务都需要经过拦截器,然后让拦截器判断是否放行该用户访问业务。

在这里插入图片描述

  • tomcat运行原理:
    在这里插入图片描述

  • 当用户发起请求时,会访问我们向tomcat注册的端口:

  • 任何程序想要运行,都需要有一个线程对当前端口号进行监听,tomcat也不例外。

  • 当监听线程知道用户想要和tomcat进行连接时,那会由监听线程创建socket连接。

    • socket都是成对出现的,用户通过socket互相传递数据,当tomcat端的socket接收到数据后,此时监听线程会从tomcat的线程池中取出一个线程执行用户请求。
  • 当我们的服务部署到tomcat后,线程会找到用户想要访问的工程,然后用这个线程转发到工程中的controller,service,dao中,并且访问对应的DB,在用户执行完请求后,再统一返回,再找到tomcat端的socket,再将数据写回到用户端的socket,完成请求和响应

  • 结论:每个用户其实对应都是去找tomcat线程池中的一个线程来完成工作的, 使用完成后再进行回收,既然每个请求都是独立的,所以在每个用户去访问我们的工程时,我们可以使用threadlocal来做到线程隔离,每个线程操作自己的一份数据(Threadlocal的基本使用)

    • 在threadLocal中,无论是它的put方法和他的get方法, 都是先从获得当前用户的线程,然后从线程中取出线程的成员变量map,只要线程不一样,map就不一样,所以可以通过这种方式来做到线程隔离。

二、集群的session共享问题(使用redis代替)

  1. session共享问题:其实就是多台tomcat服务器并不共享session存储空间(每个tomcat有自己的session),当请求切换到不同的tomcat服务时导致数据丢失的问题。

思路分析:

  • 每个tomcat中都有一份属于自己的session,假设用户第一次访问第一台tomcat,并且把自己的信息存放到第一台服务器的session中;
  • 但是第二次这个用户访问到了第二台tomcat,那么在第二台服务器上,肯定没有第一台服务器存放的session,所以此时 整个登录拦截功能就会出现问题,我们能如何解决这个问题呢?
    • 早期的方案是session拷贝,就是说虽然每个tomcat上都有不同的session,但是每当任意一台服务器的session修改时,都会同步给其他的Tomcat服务器的session,这样的话,就可以实现session的共享了,但是这种方案具有两个大问题:
      • 1、每台服务器中都有完整的一份session数据,·服务器压力过大·。
      • 2、session拷贝数据时,可能会出现延迟

解决方法:

  • 基于redis来完成,我们把session换成redis,redis数据本身就是共享的,就可以避免session共享的问题了。
    在这里插入图片描述

第一步:设计redis的value的结构

  • 利用redis来存储数据,那么到底使用哪种结构呢?
    • 如果存入的数据比较简单,我们可以考虑使用String,或者是使用哈希
      • 当存入的数据是一个对象时,value如果使用String结构时,会把java对象序列化成一个json字符串然后存储。(使用string结构时,会有一些额外的数据存储,比如json的格式等等,而且每次修改都要修改整个字符串)
      • 当存入的数据是一个对象时,value如果使用哈希,则它的value中只会存储数据本身,修改可以直接修改单个字段。
      • 如果不是特别在意内存,其实使用String就可以啦。
        在这里插入图片描述

第二步:redis的key的设计

  • 1、key要具有唯一性
  • 2、key要方便携带

第三步:设置redis的key的存活时间

  • 就好比你使用百度等其它的软件时,你每次登录进去之后,在一段时间之内,退出来再进去都不需要再重新进行登录(只要不是退出登录),过了特定的时间之后,就需要重新登录了。(原因就可以理解为存储你登录信息的数据的key过期了,存储在redis的登录数据没了)
  • 具体设计:只要用户还在操作,无论在访问哪个服务都需要重新刷新key的存活时间只有当用户不再操作的时候,才会计算key的存活时间,直到时间过去之后才会销毁key

整体访问流程

  • 用户去登录时,会去校验用户提交的手机号和验证码,是否一致,如果一致,则根据手机号查询用户信息,并将用户数据保存到redis,并且生成token作为redis的key。
    • 如果用户不存在则新建一个用户,然后将新建用户的数据保存到数据库中,然后再保存到redis,并且生成token作为redis的key,
  • 当我们校验用户是否登录时,会去携带着token进行访问,从redis中取出token对应的value,判断是否存在这个数据
    • 如果不存在这个数据则拦截登录
    • 如果存在则将其保存到threadLocal中,并且放行。

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1850747.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Vue81-独享路由守卫

一、 独享路由守卫的定义 当只有某个特定的路由需要做校验的时候,可以在改路由组件规则的地方单独配置独属于改组件的路由守卫。 二、示例 1、需求 系统只在进入新闻路由页面的时候做校验。 2、代码实现 注意: 独享路由守卫,只有前置路由守…

C语言入门系列:数据类型转换

文章目录 一,自动类型转换1,赋值运算1.1,浮点数赋值给整型变量-不安全1.2,整数赋值给浮点数变量-安全1.3,窄类型赋值给宽类型-安全1.4,宽类型赋值给窄类型-不安全 2,混合类型的运算2.1&#xff…

Kotlin 中的内联函数

1 inline 内联函数:消除 Lambda 带来的运行时开销。 举例来说: fun main() {val num1 100val num2 80val result num1AndNum2(num1, num2) { n1, n2 ->n1 n2} }fun num1AndNum2(num1: Int, num2: Int, operation: (Int, Int) -> Int): Int …

【自撰写】【国际象棋入门】第8课 国际象棋残局基础

第8课 国际象棋残局基础 一、残局的特点 残局是棋局的最后(收尾)阶段,虽然此时棋盘上的子力已经所剩无几,但依照不同的局面分类,残局中存在着许多有意思的变化,初始局面中的细小变化也可能引发到截然不同…

Redis源码学习:ziplist的数据结构和连锁更新问题

ziplist ziplist 是 Redis 中一种紧凑型的列表结构&#xff0c;专门用来存储元素数量少且每个元素较小的数据。它是一个双端链表&#xff0c; 可以在任意一端进行压入/弹出操作&#xff0c;并且该操作的时间复杂度为O(1)。 ziplist数据结构 <zlbytes><zltail>&l…

期货交易豆粕品种详细分析

文章目录 1、豆粕期货标准&#xff08;2024年6月22号数据&#xff09;2、豆粕是什么3、豆粕1、5、9合约区别4、影响豆粕的价格因素1、大豆的供应情况。2、豆粕的季节性3、油粕比&#xff08;豆油和豆粕的价格关系 &#xff09; 5、美国大豆的生产/库存炒作6、豆粕双方&#xff…

Linux中tar压缩与解压缩

TAR是Unix/Linux中常用的归档工具&#xff0c;它可以对文件或目录进行打包但不压缩&#xff0c;或者配合其他工具进行压缩。 压缩文件或目录 以下是一些基本的tar压缩命令&#xff1a; 1.压缩单个文件&#xff1a; tar -cvf archive.tar file1 2.压缩多个文件&#xff1a; t…

微软Edge浏览器全解析

微软Edge浏览器全解析(一) 解决浏览器的主页被篡改后无法通过浏览器的自带设置来恢复的问题 相信各位都有发现新买的联想电脑浏览器的主页设置不太满意,但从浏览器自带的设置上又无法解决此问题,网上找了许多方法都无济于事,特别对有着强迫症的小伙伴们更是一种煎熬。 通…

cocos 如何使用九宫格图片,以及在微信小程序上失效。

1.在图片下方&#xff0c;点击edit。 2.拖动线条&#xff0c;使四角不被拉伸。 3.使用。 其他 在微信小程序上失效&#xff0c;需要将packable合图功能取消掉。

26.2 Django简介

1. Python三大主流框架 根据当前的信息和流行度, Python的三大框架可以归纳为Django, Flask和FastAPI, 以下是对它们的清晰分点表示和归纳:* 1. Django: 一个高级的Python Web框架, 以快速开发和实用简洁的设计出名.它遵循MVC设计模式(但更倾向于MTV模式), 并提供了许多内置的…

实施高效冷却技术:确保滚珠丝杆稳定运行!

滚珠丝杆在运行过程中&#xff0c;由于摩擦、惯性力等因素&#xff0c;会产生一定的热量&#xff0c;当热量无法及时散发时&#xff0c;滚珠丝杆的温度就会升高&#xff0c;会直接影响滚珠丝杆的精度和稳定性&#xff0c;从而影响最终的产品质量。为了让滚珠丝杆保持应有的精度…

【博客719】时序数据库基石:LSM Tree的增删查改

时序数据库基石&#xff1a;LSM Tree的增删查改 LSM结构 LSM树将任何的对数据操作都转化为对内存中的Memtable的一次插入。Memtable可以使用任意内存数据结构&#xff0c;如HashTable&#xff0c;BTree&#xff0c;SkipList等。对于有事务控制需要的存储系统&#xff0c;需要在…

数据库设计文档编写

PS&#xff1a;建议使用第三种方法 方法1&#xff1a;使用 Navicat 生成数据库设计文档 效果 先看简单的效果图&#xff0c;如果效果合适&#xff0c;大家在进行测试使用&#xff0c;不合适直接撤退&#xff0c;也不浪费时间。 随后在docx文档中生成目标字段的表格&#xf…

dex文件结构(二):dex文件加载基本原理

return mClassLoader; } 1.3 ApplicationLoaders.getClassLoader public ClassLoader getClassLoader(String zip, String libPath, ClassLoader parent){ //Class.getSystemClassLoader返回的是一个PathClassLoader //baseParent是BootClassLoader ClassLoader basePare…

【仿真建模-anylogic】Network代码解析

Author&#xff1a;赵志乾 Date&#xff1a;2024-06-22 Declaration&#xff1a;All Right Reserved&#xff01;&#xff01;&#xff01; 1. 类图 2. 代码解析 //************************核心字段************************* // Network所属的level private transient Leve…

windows10远程桌面端口,Windows 10远程桌面端口修改的两个方法

在Windows 10系统中&#xff0c;远程桌面功能允许用户通过网络从一台计算机远程访问和控制另一台计算机。默认情况下&#xff0c;远程桌面服务使用的端口是3389。然而&#xff0c;出于安全考虑&#xff0c;许多管理员和用户希望修改这一默认端口。本指南将详细介绍如何在Window…

乌班图Ubuntu 24.04 SSH Server 修改默认端口重启无效

试用最新的乌班图版本&#xff0c;常规修改ssh端口&#xff0c;修改完毕后重启sshd提示没有找到service&#xff0c;然后尝试去掉d重启ssh后查看状态&#xff0c;端口仍然是默认的22&#xff0c;各种尝试都试了不行&#xff0c;重启服务器后倒是端口修改成功了&#xff0c;心想…

AcWing算法基础课笔记——高斯消元

高斯消元 用来求解方程组 a 11 x 1 a 12 x 2 ⋯ a 1 n x n b 1 a 21 x 1 a 22 x 2 ⋯ a 2 n x n b 2 … a n 1 x 1 a n 2 x 2 ⋯ a n n x n b n a_{11} x_1 a_{12} x_2 \dots a_{1n} x_n b_1\\ a_{21} x_1 a_{22} x_2 \dots a_{2n} x_n b_2\\ \dots \\ a…

陈好与王星越中戏传承

陈好与王星越&#xff1a;中戏传承&#xff0c;万人迷与未来之星在娱乐圈的星光璀璨中&#xff0c;我们时常被那些耀眼的明星所吸引&#xff0c;但你是否曾想过&#xff0c;他们背后的成长之路&#xff0c;是如何被一位位优秀的老师所指引的呢&#xff1f;今天&#xff0c;就让…

刷代码随想录有感(113):动态规划——爬楼梯plus

题干&#xff1a; 代码&#xff1a; #include<bits/stdc.h> using namespace std;int main(){int n,m;cin>>n>>m;vector<int>dp(n 1, 0);dp[0] 1;for(int j 0; j < n; j){for(int i 1; i < m; i){if(j > i)dp[j] dp[j - i];}}cout<&…