jackson使用@JsonSerialize格式化BigDecimal解决.00不显示问题

步骤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 {
  @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正确使用

实际开发中,我们一定遇到过这样的问题:前端显示和后台存储数据单位不统一,而且各有各自的理由,统一不了,那就只能由后端转换。每次返回给前端时再转换一遍,返回给前端的json数据,在后端里定义的往往是一个对象,如何做到优雅的转换呢?只需两步操作:1. 写一个负责转换的类,里面写好规则

public class MySerializerUtils extends JsonSerializer {
  @Override
  public void serialize(Integer status, JsonGenerator jsonGenerator, SerializerProvider serializerProvider) throws IOException, JsonProcessingException {
    String statusStr = "";
     switch (status) {
       case 0:
         statusStr = "新建状态";
         break;
       case 1:
        statusStr = "就绪状态";
         break;
       case 2:
         statusStr = "运行状态";
         break;
       case 3:
         statusStr = "阻塞和唤醒线程";
         break;
       case 4:
        statusStr = " 死亡状态";
        break;
       default:
         statusStr = "状态信息不符合";
     }
     jsonGenerator.writeString(statusStr);
   }
 }

2. 在实体类上需要装换的字段上加上注解

/**
 * 多线程生命周期状态值
 */
@JsonSerialize(using = MySerializerUtils.class)
private int status;

注:@JsonSerialize注解,主要应用于数据转换,该注解作用在该属性的getter()方法上。

到此这篇关于jackson使用@JsonSerialize格式化BigDecimal解决.00不显示问题的文章就介绍到这了,更多相关jackson @JsonSerialize格式化BigDecimal 

你可能感兴趣的:(spring,boot,java,spring,java,spring,spring,boot)