Redis实现Session持久化

2023-09-18 19:18:04

Redis实现Session持久化

1. 前言

直接使用Session存储用户登录信息,此时的会话信息是存储在内中的,只要项目重启存储的Session信息就会丢失。而使用Redis存储Session的话就不会存在这种情况,即使项目重启也并不影响,也无需用户重新登录。使用Redis存储Session,还能让项目支持分布式的,比如项目部署在多台机器上把多台机器的Session信息存到同一个Redis服务器上,就可以避免用户每次访问不同服务器都要进行登录的问题。

在这里插入图片描述

2. 操作步骤

  1. 添加依赖

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-data-redis</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.session</groupId>
        <artifactId>spring-session-data-redis</artifactId>
    </dependency>
    
  2. 修改配置文件

    # 指定Spring Session的存储类型为Redis,表示会将Session数据存储在Redis中
    spring.session.store-type=redis
    # 设置Session的超时时间为1800秒(30分钟)
    server.servlet.session.timeout=1800
    # 设置Redis的刷新模式为在保存时刷新,表示在Session数据保存到Redis时会刷新过期时间。
    spring.session.redis.flush-mode=on_save
    # 设置Redis的命名空间为spring:session,用于区分不同的Session数据。
    spring.session.redis.namespace=spring:session
    # 设置Redis服务器的主机地址
    spring.redis.host=120.25.124.200
    # 指定Redis服务器的密码
    spring.redis.password=
    # 指定Redis服务器的端口号
    spring.redis.port=6379
    
  3. 操作代码

    配置完Redis相关配置后,以前的代码无需修项目就可以支持Session持久化了。

    存储到Redis

    @PostMapping("/login")
    public Response login(String username, String password,HttpServletRequest request,HttpSession httpSession) {
        if (username == null || password == null || "".equals(username.trim()) || "".equals(password.trim()) ){
            return Response.fail("用户密码错误");
        }
        User user = userService.byNameUser(username);
        if (user != null && PasswordUtil.check(password,user.getPassword())) {
            HttpSession session = request.getSession(true);
            session.setAttribute(Constant.USER_SESSION,user.getUsername());
            return Response.success("登录成功");
        }
        return Response.fail("用户名密码错误");
    }
    

    从Redis中读取代码

    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        HttpSession session = request.getSession(false);
        if (session != null && session.getAttribute(Constant.USER_SESSION) != null) {
            return true;
        }
        response.sendRedirect("/login.html");
        return false;
    }
    

    SSH隧道

    在本地编写代码需要用到服务器上的Redis的时候需要开放端口,但Redis的端口一旦暴露到了公网就会非常危险,容易被黑客入侵。修改端口掩耳盗铃可以是可以,但更好的做法是使用SSH端口转发。SSH默认是走22端口,SSH功能非常强大,其中端口转发就是其中很重要的一个特性。相当于通过SSH的22号端口,来传递其他端口的数据。

    在这里插入图片描述

    本身我们是通过windows主机访问云服务器的6379端口,于是就构造了一个特殊的SSH数据报,就把要访问redis的请求,放到了SSH 数据报里。这个数据就会通过22号端口发送给服务器,服务器的SSH服务器程序,就能够解析出上诉的数据报,然后把这个数据报交给6379端口的程序。

  # 设置Redis服务器的主机地址
  spring.redis.host=127.0.0.1
  # 指定Redis服务器的密码
  spring.redis.password=
  # 指定Redis服务器的端口号
  spring.redis.port=8888

在这里插入图片描述


更多推荐

前端杂记1

React是基于函数式编程的运行时框架,UI=fn(state),它的状态改变是通过发布订阅模式,单向数据流方式,更新是通过运行时diff,然后将变化的部分渲染,而vue是通过响应式以组件为颗粒进行更新,因此它可以在预编译阶段进行动静态标记来优化更新比较过程reactscheduler会将组件根据优先级划分成更小颗粒的

Vue全局事件总线

1.简介全局事件总线时一种组件间通信的方式,适用于任意组件间通信2.原理分析:如果A组件想要传递数据给B组件,那么就通过全局事件总线在B组件中绑定一个自定义事件,并界定一个参数来接收传递的数据,在A组件中,就需要通过全局事件总线对自定义事件进行触发,并传递参数简单理解:全局事件总线其实就是一个中间介质,组件间的相互通信

flex弹性盒模型与阿里图标的使用

华子目录flex布局flex布局原理flex使用三要素阿里图标(字体)flex布局相关学习网站:http://c.biancheng.net/css3/flex.html1.flex是当前最主流的布局方式:用它布局起来更方便,取代了浮动的作用。2.浮动布局有缺陷,会脱离文档流,可能会导致布局崩塌注:用flex布局的元素

SQL中LIKE和REGEXP简单对比

一、在SQL中,LIKE和REGEXP是用于模式匹配的两种不同语法。它们用于在数据库查询中匹配符合特定模式的字符串。1.LIKE是SQL中用于模糊匹配的运算符,它使用通配符%来表示任意个数字符序列(包括空字符序列)的位置。例如:SELECT*FROMtable_nameWHEREcolumn_nameLIKE'AA%'

Dubbo可以代替Feign、Hystrix、Sentinel,Ribbon?

文章目录一、概念二、功能介绍1、@Service2、@Reference3、@Method4、@Argument三、分析四、如何实现?1、熔断(CircuitBreaker)XML配置方式注解方式2、降级(Fallback)XML配置方式注解方式3、限流(RateLimiting)XML配置方式注解方式4、负载均衡(L

华为云云耀云服务器L实例评测|华为云上安装kafka

文章目录华为云云耀云服务器L实例评测|华为云上安装kafka一、kafka介绍二、华为云主机准备三、kafka安装1.安装什么版本java2.安装zookeeper服务3.使用systemctl管理启动ZooKeeper服务4.修改kafka配置5.使用systemctl管理启动kafka服务6.创建一个测试topic

从零开始学网站建设:从需求分析到上线发布

从零开始学网站建设:从需求分析到上线发布一、需求分析首先,要成功地建设一个网站,需要进行深入的需求分析。这涉及到与潜在用户进行沟通,了解他们的需求和期望。在这个过程中,我们需要明确网站的目标和定位,以便确定网站的功能和设计。二、制定网站建设方案在需求分析的基础上,制定出一个详细的网站建设方案。这包括网站的结构设计、功能

Python-Jenkins 在 Jenkins 中的应用

Author:rabPython版本:3.9Jenkins版本:2.409官方文档:https://python-jenkins.readthedocs.io/en/latest/目录前言一、案例1.1管理JenkinsVersion1.2管理JenkinsJob1.2.1普通创建Job1.2.2获取当前用户的所有Jo

八股整理(计网,os)

1.进程和线程的区别1.1什么是进程和线程1.进程是操作系统进行资源分配和调度的一个基本单位,资源包括cpu,内存,磁盘等等IO设备等等。每一个进程启动都会最先产生一个线程,即主线程,然后主线程会在创建其他的子线程。2.线程是一个基本的cpu执行单元,必须依托进程存货,一个线程是一个executioncontext(执

Android如何实现轮播效果:ViewFlipper 和 ViewAnimator

前言现在的app中基本上都有轮播的需求,比如广告banner、最新消息tips等等。其中我们熟悉的顶部广告一般左右轮播,这种情况大部分通过ViewPager实现。而那种上下轮播的消息tips(一般是条状)则可以使用ViewFlipper实现。说到ViewFlipper,就不得不先说ViewAnimator,它是View

接口自动化测试框架搭建【附详细搭建视频】

如果遇到什么问题建议观看下面视频:【敢称全站第一】B站最全的Python自动化测试深度学习教程!学完即就业,小白也能信手拈来!帮你少走99%的弯路~一、原理及特点参数放在XML文件中进行管理用httpClient简单封装一个httpUtils工具类测试用例管理使用了testNg管理,使用了TestNG参数化测试,通过x

热文推荐