欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

@JsonSerialize不起作用的解决方案

程序员文章站 2022-06-19 17:50:02
目录@jsonserialize不起作用在项目中 当字段实体类为long类型时@jsonserialize正确使用@jsonserialize不起作用在项目中 当字段实体类为long类型时如果long...

@jsonserialize不起作用

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

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

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

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

这个时候我们可以用@jsonserialize,在json序列化的时候把long自动转为string,

但是这里有个小坑

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

@jsonserialize(using = tostringserializer.class)
private long parentid;    //转化成功
@jsonserialize(using = tostringserializer.class)
private long parentid;    //转化失败

@jsonserialize正确使用

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

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

1. 写一个负责转换的类

里面写好规则

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

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

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

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