Long類型轉json時前端js丟失精度解決方案

出自:https://www.cnblogs.com/lvgg/p/7475140.htmlhtml

1、問題背景

Java後端開發過程當中,尤爲是id字段,因數值太大,經過json形式傳輸到前端後,在js解析時,會丟失精度。前端

若是對精度丟失沒有什麼概念,能夠看一個知乎的帖子,來感覺一下:https://www.zhihu.com/question/34564427?sort=createdjson

2、解決思路

將id字段序列化爲json時,轉換爲字符串類型,前端傳輸到後端,反序列化時,再從新轉換爲Long。後端

3、具體實現

在dto所在項目中,新建一個helper包(名字自定義,也能夠放現有包裏)。PS:爲何要建到dto項目中?由於,這個包最後可能會給其餘組使用,這樣以來,全部的處理規則邏輯都是統一的,方便對接。ide

在包裏添加類LongJsonSerializer,代碼以下:spa

/**
 * Long 類型字段序列化時轉爲字符串,避免js丟失精度
 *
 */
public class LongJsonSerializer extends JsonSerializer<Long> {
    @Override
    public void serialize(Long value, JsonGenerator jsonGenerator, SerializerProvider serializerProvider) throws IOException, JsonProcessingException {
        String text = (value == null ? null : String.valueOf(value));
        if (text != null) {
            jsonGenerator.writeString(text);
        }
    }
}

 

而後在包裏再添加類LongJsonDeserializer,代碼以下:code

/**
 * 將字符串轉爲Long
 *
 */
public class LongJsonDeserializer extends JsonDeserializer<Long> {
    private static final Logger logger = LoggerFactory.getLogger(LongJsonDeserializer.class);
  
    @Override
    public Long deserialize(JsonParser jsonParser, DeserializationContext deserializationContext) throws IOException, JsonProcessingException {
        String value = jsonParser.getText();
        try {
            return value == null ? null : Long.parseLong(value);
        } catch (NumberFormatException e) {
            logger.error("解析長整形錯誤", e);
            return null;
        }
    }
}

 

好了,接下來是使用這兩個類。orm

在須要處理的id字段上,加上註解。好比以下代碼:htm

/**
 * id
 */
@JsonSerialize(using = LongJsonSerializer.class)
@JsonDeserialize(using = LongJsonDeserializer.class)
private Long id;
相關文章
相關標籤/搜索