记录一下再反序列化时碰见的错误

记录一下再反序列化时碰见的错误

在项目中碰见一个错误

onException: Could not read JSON: Could not resolve type id 'com.zjcds.tj.server.domain.bean.KpiCacheBean' as a subtype of [simple type, class java.lang.Object]: no such class found  at [Source: (byte[])"["com.zjcds.tj.server.domain.bean.KpiCacheBean",{"kpi":97,"generatorTime":1547446107944}]"; line: 1, column: 49];

nested exception is com.fasterxml.jackson.databind.exc.InvalidTypeIdException: Could not resolve type id 'com.zjcds.tj.server.domain.bean.KpiCacheBean' as a subtype of [simple type, class java.lang.Object]: no such class found

这里出现的问题是无效类型异常,就是说在反序列化实体类的时候部分字段没有映射出来,导致出现类型不一致的问题,因此比较json和实体类中的子段,将不需要的字段进行忽略就行了。
fastjson就在相关字段上面加注解
@JsonInclude(JsonInclude.Include.NON_DEFAULT)
或者加
@JSONField(serialize = false)
或者直接在属性上加
transient private String testName;
jackson就加
@JsonIgnore注解用来忽略某些字段,可以用在Field或者Getter方法上,用在Setter方法时,和Filed效果一样。这个注解只能用在POJO存在的字段要忽略的情况,不能满足现在需要的情况。
@JsonIgnoreProperties(ignoreUnknown = true),将这个注解写在类上之后,就会忽略类中不存在的字段,可以满足当前的需要。这个注解还可以指定要忽略的字段。使用方法如下:
@JsonIgnoreProperties({ “internalId”, “secretKey” })
指定的字段不会被序列化和反序列化。

这个错误通常是由于在使用Redis进行对象序列化和反序列化,无法解析类型标识造成的。在Redis中,对象序列化后的字节流会包含一个类型标识,以便在反序列化可以正确地恢复对象的类型。 解决这个问题的方法之一是确保在序列化和反序列化过程中都使用相同的序列化器,并且配置序列化器来处理类型标识。对于Spring Data Redis,可以使用Jackson序列化器来处理对象的序列化和反序列化。 首先,确保您的对象类上具有正确的Jackson注解,如`@JsonTypeInfo`和`@JsonSubTypes`,以便在序列化包含类型标识。例如: ```java @JsonTypeInfo(use = JsonTypeInfo.Id.CLASS, include = JsonTypeInfo.As.PROPERTY, property = "@class") public class YourObject { // ... } ``` 接下来,在Redis配置中配置Jackson序列化器,并设置默认类型。例如,在Spring Boot应用中,可以通过以下方式配置: ```java @Configuration public class RedisConfig { @Bean public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory connectionFactory) { RedisTemplate<String, Object> template = new RedisTemplate<>(); template.setConnectionFactory(connectionFactory); Jackson2JsonRedisSerializer<Object> serializer = new Jackson2JsonRedisSerializer<>(Object.class); ObjectMapper objectMapper = new ObjectMapper(); objectMapper.activateDefaultTyping(LaissezFaireSubTypeValidator.instance, ObjectMapper.DefaultTyping.NON_FINAL); serializer.setObjectMapper(objectMapper); template.setDefaultSerializer(serializer); template.setValueSerializer(serializer); return template; } } ``` 这样配置后,Redis将使用Jackson序列化器进行对象的序列化和反序列化,并正确处理类型标识。请注意,这里使用`activateDefaultTyping`方法来激活默认类型,以便在反序列化可以正确地恢复对象的类型。 希望这可以帮助您解决问题!如果还有其他问题,请随提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值