问题:在进行后端接口调试的时候,发现无法更新数据,最后发现是因为id的最后两位全部变为00。后端人员说ID的类型设置为long,而前端是Number类型,超过了17位发生溢出,不使用String是因为数据库的效率问题。
解决方案:
- 后端:在发送数据之前通过注解的方式将long转为string
- 前端:在接收数据的时候通过success回调函数进行处理转为string
最后是后端人员解决了这个问题,因为后端的接口会被其他人员调用,从源头解决方便太多
后端:
第一种
@JsonSerialize(using = ToStringSerializer.class)
private Long id;
第二种
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.module.SimpleModule;
import com.fasterxml.jackson.databind.ser.std.ToStringSerializer;
import org.springframework.context.annotation.Configuration;
import org.springframework.http.converter.HttpMessageConverter;
import org.springframework.http.converter.json.MappingJackson2HttpMessageConverter;
import org.springframework.web.servlet.config.annotation.EnableWebMvc;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurerAdapter;
import java.util.List;
//implements WebMvcConfigurer 可代替
@Configuration
//@EnableWebMvc
public class WebJsonConverterConfig extends WebMvcConfigurerAdapter {
@Override
public void configureMessageConverters(List<HttpMessageConverter<?>> converters) {
MappingJackson2HttpMessageConverter jackson2HttpMessageConverter = new MappingJackson2HttpMessageConverter();
ObjectMapper objectMapper = new ObjectMapper();
SimpleModule simpleModule = new SimpleModule();
simpleModule.addSerializer(Long.class, ToStringSerializer.instance);
simpleModule.addSerializer(Long.TYPE, ToStringSerializer.instance);
objectMapper.registerModule(simpleModule);
jackson2HttpMessageConverter.setObjectMapper(objectMapper);
converters.add(jackson2HttpMessageConverter);
}
}
本文探讨了后端接口中由于ID类型设置导致的长整型溢出问题,介绍了后端通过注解和Spring配置解决方法,以及前端如何处理接收到的字符串ID。通过这些调整,确保了数据更新的正确性和接口的通用性。
2019

被折叠的 条评论
为什么被折叠?



