SpringBoot+Redis 集成验证码的简单案例

SpringBoot+Redis 集成验证码的简单案例

一次学习过程中简单的记录

一、下载安装Redis

这里就不多说了,下载安装好Redis,最好是把Redis Desktop Manager一起安装了,可视化看的舒服一点。

二、代码部分

1.引入Redis依赖,这里我的springboot版本是2.4.2

1
2
3
4
5
6
7
8
9
xml复制代码<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-pool2</artifactId>
<version>2.10.0</version>
</dependency>

验证码依赖

1
2
3
4
5
xml复制代码<dependency>
<groupId>com.github.whvcse</groupId>
<artifactId>easy-captcha</artifactId>
<version>1.6.2</version>
</dependency>

yml配置,这里就简单配置做示例,小伙伴们根据自己的业务需求来配置哈~

1
2
3
4
5
6
7
8
9
10
11
12
13
yaml复制代码server:
port: 8081
spring:
redis:
database: 3
jedis:
pool:
max-active: 8
max-wait: -1
lettuce:
pool:
min-idle: 0
timeout: 5000

2.编写RedisConfig

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
java复制代码@Configuration
public class RedisConfig extends CachingConfigurerSupport {

@Bean
@SuppressWarnings("all")
public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory) {
RedisTemplate<String, Object> redisTemplate = new RedisTemplate<String, Object>();
StringRedisSerializer keySerializer = new StringRedisSerializer();
GenericFastJsonRedisSerializer valueSerializer = new GenericFastJsonRedisSerializer();
redisTemplate.setConnectionFactory(redisConnectionFactory);
// 序列化 key 和 value
redisTemplate.setKeySerializer(keySerializer);
redisTemplate.setValueSerializer(valueSerializer);
redisTemplate.setHashKeySerializer(keySerializer);
redisTemplate.setHashValueSerializer(valueSerializer);
return redisTemplate;
}
}

3.编写RedisUtils

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
java复制代码@Component
public class RedisClient {

@Resource
private RedisTemplate<String, Object> redisTemplate;

/*
* @ClassName RedisClient
* @Desc TODO 设置缓存(没有时间限制)
* @Date 2021-07-24 16:11
* @Version 1.0
*/
public void set(String key, Object value) {
redisTemplate.opsForValue().set(key, value);
}

/*
* @ClassName RedisClient
* @Desc TODO 设置缓存(有时间限制,单位为 秒)
* @Date 2021-07-24 16:11
* @Version 1.0
*/
public void set(String key, Object value, long timeout) {
redisTemplate.opsForValue().set(key, value, timeout, TimeUnit.SECONDS);
}

/*
* @ClassName RedisClient
* @Desc TODO 删除缓存,并返回是否删除成功
* @Date 2021-07-24 16:11
* @Version 1.0
*/
public boolean delete(String key) {
redisTemplate.delete(key);
// 如果还存在这个 key 就证明删除失败
if (redisTemplate.hasKey(key)) {
return false;
// 不存在就证明删除成功
} else {
return true;
}
}

/*
* @ClassName RedisClient
* @Desc TODO 取出缓存
* @Date 2021-07-24 16:12
* @Version 1.0
*/
public Object get(String key) {
if (redisTemplate.hasKey(key)) {
return redisTemplate.opsForValue().get(key);
} else {
return null;
}
}

/*
* @ClassName RedisClient
* @Desc TODO 获取失效时间(-2:失效 / -1:没有时间限制)
* @Date 2021-07-24 16:15
* @Version 1.0
*/
public long getExpire(String key) {
// 判断是否存在
if (redisTemplate.hasKey(key)) {
return redisTemplate.getExpire(key);
} else {
return Long.parseLong(-2 + "");
}
}

4.编写Controller测试

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
java复制代码@Controller
@ResponseBody
public class CaptchaController {

@Resource
private RedisClient redisClient;

@GetMapping("/captcha")
public void captcha(HttpServletRequest request, HttpServletResponse response) throws Exception {
SpecCaptcha specCaptcha = new SpecCaptcha(130, 48, 4);
specCaptcha.setFont(Captcha.FONT_1);
String id = UUID.randomUUID().toString();
response.setHeader("id", id);
CaptchaUtil.out(specCaptcha, request, response);
String verCode = specCaptcha.text().toLowerCase();
redisClient.set(id, verCode);//可设置有效时间,单位为秒
}

@PostMapping(value = "/check")
public boolean check(@RequestBody String info) {
JSONObject jsonObject = JSON.parseObject(info);
String id = jsonObject.getString("id");
String code = jsonObject.getString("code");
String s = redisClient.get(id).toString();//id
return code.equalsIgnoreCase(s);
}
}

访问localhost:8081/captcha 别忘了启动Redis

在这里插入图片描述
这里的id就是存进Redis的键

在这里插入图片描述
我们拿到Redis的键再去请求 localhost:8081/check 验证我们的验证码是否是正确的
在这里插入图片描述

到这里就结束啦,小白的一次简单验证码的集成~,有不对的地方欢迎指正

本文转载自: 掘金

开发者博客 – 和开发相关的 这里全都有

0%