七叶笔记 » java编程 » SpringBoot详解如何整合Redis缓存验证码

SpringBoot详解如何整合Redis缓存验证码

1、简介

Redis is an open source (BSD licensed), in-memory data structure store, used as a database, cache, and message broker.

翻译:Redis 是一个开源的内存中的数据结构存储系统,它可以用作:数据库、缓存和消息中间件。

官网链接:https://redis.io

Redis 是用 C 语言开发的一个开源的高性能键值对(key-value)数据库,官方提供的数据是可以达到 **100000+**的 QPS。

QPS(Queries-per-second),每秒内查询次数。(百度百科)

它存储的 value 类型比较丰富,也被称为结构化的 NoSQL 数据库。

NoSQL(Not only SQL),不仅仅是 SQL,泛指非关系型数据库。

NoSQL 数据库并不是要取代关系型数据库,而是关系型数据库的补充。

关系型数据库(RDBMS)

MySQLOracleDB2SQL Server

非关系型数据库(NoSQL)

RedisMongo dbMemCached

Redis 应用场景

缓存任务队列消息队列分布式锁

2、介绍

Redis 的 Java 客户端很多,官方推荐的有三种:Jedis、Lettuce、Redisson。

Spring 对 Redis 客户端进行了整合,提供了 Spring Data Redis。

在 Spring Boot 项目中还提供了对应的 Starter,即 spring-boot-starter-data-redis。

在这里直接使用的是Spring Data Redis,且不展示Redis的下载和安装过程啦。

3、前期配置

3.1、坐标导入

在创建完成Spring Boot项目之后,在pom.xml中加入spring-boot-start-data-redis的依赖坐标

3.2、配置文件

这里忽略了其他的配置如MySQL这些,只突出Redis的配置信息

spring:   # Redis配置  redis:    host: localhost    port: 6379    # 根据自己设置的密码决定    password: 123456    # 操作0号数据库,默认有16个数据库    database: 0    jedis:      pool:        max-active: 8 # 最大连接数        max-wait: 1ms # 连接池最大阻塞等待时间        max-idle: 4   # 连接池中的最大空闲连接        min-idle: 0   # 连接池中的最小空闲连接

3.3、配置类

使用 springboot 整合 redis 的专用客户端接口操作。此处使用的是 SpringBoot 框架提供的 RedisTemplate。

RedisTemplate 在处理 key 和 value 时,会对其进行序列化操作,这就会导致一些问题。

比如:输入的 key 值是 city,但 redis 获得到的 key 值却是 xac]xedx00x05tx00x04city。

因此就需要一个专门的配置类,来专门处理 RedisTemplate 默认的序列化处理所导致的问题。

值得注意的是,这里是重新加载一个新的序列化器来取代原来的序列化器,这就证明着其原本是有着自己默认的序列化器JdkSerializationRedisSerializer。

4、Java操作Redis

在这里由于代码比较隐私(主要是懒得整理登录和生成验证码的接口放在这里),因此这里就直接使用测试类进行演示。

发送验证码

输入验证码登录

到这里Redis的简单整合就完成啦,这里的Redis使用仍是比较简单的,验证码也只是Redis的一个最简单使用方式之一而已,在后续狗子我将会尝试Redis的其他用法,在没有偷懒的时候写好笔记记录下来!

到此这篇关于SpringBoot详解如何整合Redis缓存验证码的文章就介绍到这了,更多相关SpringBoot Redis缓存验证码内容请搜索七叶笔记以前的文章或继续浏览下面的相关文章希望大家以后多多支持七叶笔记!

相关文章