好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

@JsonSerialize不起作用的解决方案

@JsonSerialize不起作用

在项目中 当字段实体类为Long类型时

如果Long值超过前端js显示的长度范围时会导致前端回显错误

此时我们想到的解决方案是将Long值返回给前端时转为String,

但是我们又不想变更字段的类型,当然我们也不想额外添加新的字段。

这个时候我们可以用@JsonSerialize,在Json序列化的时候把Long自动转为String,

但是这里有个小坑

被转换的字段必须是包装类类型,否则会转换失败。

?

1

2

@JsonSerialize (using = ToStringSerializer. class )

private Long parentId;    //转化成功

?

1

2

@JsonSerialize (using = ToStringSerializer. class )

private long parentId;    //转化失败

@JsonSerialize正确使用

实际开发中,我们一定遇到过这样的问题:前端显示和后台存储数据单位不统一,而且各有各自的理由,统一不了,那就只能由后端转换。

每次返回给前端时再转换一遍,返回给前端的json数据,在后端里定义的往往是一个对象,如何做到优雅的转换呢?只需两步操作:

1. 写一个负责转换的类

里面写好规则

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

public class MySerializerUtils extends JsonSerializer<Integer> {

    @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. 在实体类上需要装换的字段上加上注解

?

1

2

3

4

5

/**

  * 多线程生命周期状态值

  */

@JsonSerialize (using = MySerializerUtils. class )

private int status;

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

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。

原文链接:https://blog.csdn.net/m0_37980582/article/details/103702651

查看更多关于@JsonSerialize不起作用的解决方案的详细内容...

  阅读:132次