项目场景:
项目场景:做苍穹外卖项目时,使用redis缓存字符串类型的数据来表示店铺营业状态.
/**
* 设置店铺营业状态
*
* @param status
* @return
*/
@PutMapping("/{status}")
@ApiOperation("设置店铺营业状态")
public Result setStatus(@PathVariable Integer status) {
("设置店铺营业状态:{}", status == 1? "营业中" : "打样中");
().set(KEY, status);
return ();
}
问题描述
修改店铺状态时,错误信息为Integer类型的数据不能转换为String类型存储在redis中.
2023-08-20 06:14:12.477 ERROR 28204 --- [nio-8080-exec-1] .[.[.[/].[dispatcherServlet] : () for servlet [dispatcherServlet] in context with path [] threw exception [Request processing failed; nested exception is : class cannot be cast to class ( and are in module of loader 'bootstrap')] with root cause
: class cannot be cast to class ( and are in module of loader 'bootstrap')
at (:36) ~[spring-data-redis-2.7.:2.7.2]
原因分析:
-value中的value可以赋值任何类型的数据,会将该数据转换成String类型存储在redis中,理论上来说是可以存储Integer类型的数据.
2.查看了RedisTemplate 配置类,发现//设置redis的序列化器为字符串类型.与标准代码不符合.
和setKeySerializer都是RedisTemplate类中的方法,用于设置序列化方式。其中,setDefaultSerializer()方法用于设置默认的序列化方式,而setKeySerializer()方法则用于设置存储在Redis中的key的序列化方式。具体来说,如果使用了setDefaultSerializer()方法设置了默认的序列化方式,那么在使用RedisTemplate对象进行操作时,如果没有指定key的序列化方式,则会使用默认的序列化方式进行存储。而如果使用了setKeySerializer()方法设置了key的序列化方式,则在使用RedisTemplate对象进行操作时,如果没有指定value的序列化方式,则会使用key的序列化方式进行存储。
@Bean
public RedisTemplate redisTemplate(RedisConnectionFactory redisConnectionFactory){
("开始配置redis模版对象:{}",redisConnectionFactory);
RedisTemplate redisTemplate = new RedisTemplate();
//设置redis的连接公场对象.
(redisConnectionFactory);
//设置redis的序列化器为字符串类型.
(new StringRedisSerializer());
return redisTemplate;
}
解决方案:
将//设置redis的序列化器为字符串类型.修改为
(new StringRedisSerializer());