从后端返回的id是根据雪花算法生成的id,类型为long,这个类型传到后端超过16位的部分会变成0,这就是所谓的丢失进度。
解决方法:将这个long类型的数据转换为String类型
如果我们将涉及到的实体类和属性逐一处理那么必然繁琐,所以可以借助工具类进行全局处理
下面介绍在springboot中一种统一处理方式,就是创建一个WebMvcConfig 配置类并实现 WebMvcConfigurer接口,然后通过实现方法extendMessageConverters来扩展mvc框架的消息转换器**
具体操作步骤:
首先要创建一个对象映射器JacksonObjectMapper继承自ObjectMapper,当然在这个类中可以通过SimpleModule来自定义序列化,如添加日期格式化等,代码如下:
/**
* 对象映射器:基于jackson将Java对象转为json,或者将json转为Java对象
* 将JSON解析为Java对象的过程称为 [从JSON反序列化Java对象]
* 从Java对象生成JSON的过程称为 [序列化Java对象到JSON]
*/
public class JacksonObjectMapper extends ObjectMapper {
public static final String DEFAULT_DATE_FORMAT = "yyyy-MM-dd";
public static final String DEFAULT_DATE_TIME_FORMAT = "yyyy-MM-dd HH:mm:ss";
public static final String DEFAULT_TIME_FORMAT = "HH:mm:ss";
public JacksonObjectMapper() {
super();
//收到未知属性时不报异常
this.configure(FAIL_ON_UNKNOWN_PROPERTIES, false);
//反序列化时,属性不存在的兼容处理
this.getDeserializationConfig().withoutFeatures(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES);
SimpleModule simpleModule = new SimpleModule()
.addDeserializer(LocalDateTime.class, new LocalDateTimeDeserializer(DateTimeFormatter.ofPattern(DEFAULT_DATE_TIME_FORMAT)))
.addDeserializer(LocalDate.class, new LocalDateDeserializer(DateTimeFormatter.ofPattern(DEFAULT_DATE_FORMAT)))
.addDeserializer(LocalTime.class, new LocalTimeDeserializer(DateTimeFormatter.ofPattern(DEFAULT_TIME_FORMAT)))
.addSerializer(BigInteger.class, ToStringSerializer.instance)
.addSerializer(Long.class, ToStringSerializer.instance)
.addSerializer(LocalDateTime.class, new LocalDateTimeSerializer(DateTimeFormatter.ofPattern(DEFAULT_DATE_TIME_FORMAT)))
.addSerializer(LocalDate.class, new LocalDateSerializer(DateTimeFormatter.ofPattern(DEFAULT_DATE_FORMAT)))
.addSerializer(LocalTime.class, new LocalTimeSerializer(DateTimeFormatter.ofPattern(DEFAULT_TIME_FORMAT)));
//注册功能模块 例如,可以添加自定义序列化器和反序列化器
this.registerModule(simpleModule);
}
}
使用SimpleModule.addSerializer方法将java对象序列化到JSON,关键语句如下
.addSerializer(Long.class, ToStringSerializer.instance)
然后创建配置类WebMvcConfig配置类,实现WebMvcConfigure,然后实现extendMessageConverters来扩展消息转换器
@Slf4j
@Configuration
public class WebMvcConfig implements WebMvcConfigurer {
/*
* 扩展mvc框架的消息转换器
* */
@Override
public void extendMessageConverters(List<HttpMessageConverter<?>> converters) {
log.info("扩展消息转换器...");
//创建消息转换器对象
MappingJackson2HttpMessageConverter messageConverter = new MappingJackson2HttpMessageConverter();
//设置对象转换器,底层使用Jackson将java对象转换为json
messageConverter.setObjectMapper(new JacksonObjectMapper());
//将上面的消息转换器对象追加到mvc框架的转换器集合中
converters.add(0,messageConverter);
}
}
当然在WebMvcConfig implements WebMvcConfigurer也可以使用WebMvcConfig extends WebMvcConfigrationSupport,但是这样配置类的自动配置就失效,那么会出现静态资源无法访问的情况,就需要设置静态资源映射,操作如下
@Slf4j
@Configuration
public class WebMvcConfig extends WebMvcConfigrationSupport{
//设置静态资源映射
protected void addResourceHandlers(ResourceHandlerRegistry registry){
log.info("开始进行静态资源映射")
registry.addResourceHandler("/backend/**").addResourceLocations("classpath:/backend/");
registry.addResourceHandler("/front/**").addResourceLocations("classpath:/front/");
}
/*
* 扩展mvc框架的消息转换器
* */
@Override
public void extendMessageConverters(List<HttpMessageConverter<?>> converters) {
log.info("扩展消息转换器...");
//创建消息转换器对象
MappingJackson2HttpMessageConverter messageConverter = new MappingJackson2HttpMessageConverter();
//设置对象转换器,底层使用Jackson将java对象转换为json
messageConverter.setObjectMapper(new JacksonObjectMapper());
//将上面的消息转换器对象追加到mvc框架的转换器集合中
converters.add(0,messageConverter);
}
}
以上仅为Springboot项目中的配置方式,除此之外在不同开发环境,不同项目都有自己的方式,如Jackson 工具序列化对象或者SpringMVC 配置等方式