1:新建一个springboot项目,选择web和nosql数据库。
2:编写配置文件
3:修改远程的Linux服务器上的redis的配置。
1):把Linux的防火墙关闭: systemctl stop firewalld.service:关闭防火墙 systemctl status firewalld:查看防火墙状态 2):修改redis.windows.conf 注释掉bind 127.0.0.1可以使所有的ip访问redis 把protected-mode yes改为protected-mode no
4:编写Controller *** 作redis数据库
package com.dongmu.controller; import org.springframework.data.redis.core.RedisTemplate; import org.springframework.data.redis.core.ValueOperations; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.ResponseBody; import javax.annotation.Resource; @Controller public class MyController { @Resource private RedisTemplateredisTemplate; @PostMapping("/insert") @ResponseBody public String redis(){ ValueOperations operations = redisTemplate.opsForValue(); operations.set("name","lisi"); return "向redis中添加了一行数据。"; } @PostMapping("/query") @ResponseBody public String getRedis(String k){ System.out.println(k); ValueOperations operations = redisTemplate.opsForValue(); Object o = operations.get("name"); System.out.println(o); return "ok"; } }
5:使用postman测试:
我们可以发现添加后的数据有一段前缀的代码,这是由于java序列化导致的,我们下面设置使用string的序列化进行存储。
string的序列化
@Resource private StringRedisTemplate stringRedisTemplate; @PostMapping("/insert2") @ResponseBody public String redis2(){ ValueOperations operations = stringRedisTemplate.opsForValue(); operations.set("oldname","zhangsan"); return "向redis中添加了一行数据。"; } @PostMapping("/query2") @ResponseBody public String getRedis2(String k){ System.out.println(k); ValueOperations operations = stringRedisTemplate.opsForValue(); Object o = operations.get("oldname"); System.out.println(o); return "获取到的数据"+o; }
这个时候就不会出现前缀了。 我们注入的两个对象:StringRedisTemplate 和 RedisTemplate 是框架给我们创建好的,只要加入了这个依赖就会有org.springframework.boot spring-boot-starter-data-redis
实际上即使我们使用你redisTemplate也可以使用string的序列化方式
@PostMapping("/insert") @ResponseBody public String redis(){ redisTemplate.setKeySerializer(new StringRedisSerializer()); redisTemplate.setValueSerializer(new StringRedisSerializer()); ValueOperations operations = redisTemplate.opsForValue(); operations.set("name3","sdsdsd"); return "向redis中添加了一行数据。"; }
这样就可以使用了。
自定义序列化方式
除了这种我们还可以指定序列化的格式是json格式,如下:
@PostMapping("/insert3") @ResponseBody public String redis3(){ redisTemplate.setKeySerializer(new StringRedisSerializer()); redisTemplate.setValueSerializer(new Jackson2JsonRedisSerializer (Student.class)); ValueOperations operations = redisTemplate.opsForValue(); Student student = new Student(1001,"lisi","55202362"); operations.set("student1",student); return "向redis中添加了一行数据。"; } @PostMapping("/query3") @ResponseBody public String getRedis3(String k){ System.out.println(k); redisTemplate.setKeySerializer(new StringRedisSerializer()); redisTemplate.setValueSerializer(new Jackson2JsonRedisSerializer (Student.class)); ValueOperations operations = redisTemplate.opsForValue(); Object o = operations.get("student1"); System.out.println(o); return "获取到的数据:"+o; }
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)