目录
[一、导入Spring Data Redis的依赖](#一、导入Spring Data Redis的依赖)
一、导入Spring Data Redis的依赖
由于我使用了依赖版本管理,所以我这里不需要声明dependency的version。
java
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
二、配置application.yml文件
在application.yml添加以下参数。
java
spring:
data:
redis:
host: 192.168.10.101 #这里改成自己服务器的ip地址
port: 6379 #填入自己服务器redis配置的端口
database: 0 #默认使用数据库0,可以选择0~15
三、RedisTemplate的使用
RedisTemplate封装了对redis对各种类型操作的方法,使得Java程序可以通过调用API来编写程序操作redis数据库。
|-----------------------------------|--------------------|
| 分组 | 说明 |
| redisTemplate.opsForValue() | 对string类型操作的方法 |
| redisTemplate.opsForList() | 对list类型操作的方法 |
| redisTemplate.opsForSet() | 操作set类型的方法 |
| redisTemplate.opsForHash() | 操作hash类型的方法 |
| redisTemplate.opsForZSet() | 操作zset类型的方法 |
| redisTemplate | 通用方法 |
测试RedisTemplate:
java
@SpringBootTest
public class TestRedisTemplate {
@Autowired
private RedisTemplate redisTemplate;
@Test
public void testSet(){
redisTemplate.opsForValue().set("key1","value1"); //创建一个key1:"value1"的string类型的键值对
}
@Test
public void testGet(){
String result = (String)redisTemplate.opsForValue().get("key1"); //测试通过键获取值
System.err.println(result);
}
@Test
public void testDel(){
redisTemplate.delete("key1"); //测试删除以key1为键的键值对
}
}
测试结果:
查看结果我们会发现出现了乱码,那么这是为什么呢?那么会不会影响我们通过key来获取value呢?

获取value方法测试结果:
①通过程序获取:有结果!

②通过Redis客户端命令行获取:无结果!

乱码原因:
Redis中的key和value均是以二进制 的形式存储的,因此客户端输入的key和value都会经过序列化之后才发往Redis服务端。而RedisTemplate所使用序列化方式和命令行客户端采用序列化方式不相同,进而导致序列化之后的二进制数据不同,所以才会导致上述的现象。
RedisTemplate默认使用的是Jdk序列化方式,跟客户端的序列化不一样。

使用StringRedisTemplate:
为解决上述问题,可使用**StringRedisTemplate** 代替**RedisTemplate** ,因为**StringRedisTemplate**使用的序列化器和命令行所使用的序列化器是相同的。
对比RedisTemplate,StringRedisTemplate使用的序列化是Redis自带的序列化方式。
查看源码:

测试:
java
@SpringBootTest
public class TestStringRedisTemplate {
@Autowired
private StringRedisTemplate redisTemplate;
@Test
public void testSet() {
redisTemplate.opsForValue().set("key4", "value4");
}
@Test
public void testGet() {
String result = redisTemplate.opsForValue().get("key4");
System.out.println(result);
}
@Test
public void testDel() {
redisTemplate.delete("key4");
}
}
测试set方法结果:成功创建key4:value4键值对,并且没有出现乱码。

测试get方法结果:成功获取value4。

测试客户端获取值:也成功,说明序列化问题解决了!
