一、 问题
最近开发中使用BigDecimal这个数据类型 返回json数据时出现了点问题:
# 1.前端第一次保存的时候 穿过来的数据格式
240.00
240.77
# 2. mysql数据库存储的数据格式(数据库字段已经设置了保留小数点后两位)
240
240.77
# 3. java程序中查看从数据库中查询的回来的数据格式:
240.00
240.77
# 4. 返回前端的json字符串里的数据格式:
240
240.77
# 4. 前端想要的json字符串里的数据格式:
240.00
240.77
由上面的一系列分析可知:要想解决这个根源在于返回json数据的时候需要将数据格式化。
二、解决方案:使用@JsonSerialize输出数据保留两位小数
步骤1.创建一个BigDecimal格式化工具
import com.fasterxml.jackson.core.JsonGenerator;
import com.fasterxml.jackson.databind.JsonSerializer;
import com.fasterxml.jackson.databind.SerializerProvider;
import java.io.IOException;
import java.math.BigDecimal;
public class BigDecimalSerialize extends JsonSerializer<BigDecimal> {
@Override
public void serialize(BigDecimal value, JsonGenerator gen, SerializerProvider serializerProvider) throws IOException {
if (value != null && !"".equals(value)) {
gen.writeString(value.setScale(2, BigDecimal.ROUND_HALF_DOWN) + "");
} else {
gen.writeString(value + "");
}
}
}
步骤二:在返回的实体类对应的属性上加上注解:
@JsonSerialize(using = BigDecimalSerialize.class)
private BigDecimal totalCost;
总结
这个方案可以统一解决json的Date日期类型,String类型。double类型。。。等等的序列化格式问题
@JsonSerialize正确使用 https://juejin.im/post/5c91ad28e51d4574ed4ee0a3