fastjson在反序列化时,怎么解析对象中的继承

发布于 2022-09-01 05:11:52 字数 1118 浏览 27 评论 0

例子:

import com.alibaba.fastjson.JSON;

public class Text {

    private A a;

    class A {

        private String a;

        public String getA() {
            return a;
        }

        public void setA(String a) {
            this.a = a;
        }

    }

    class B extends A {

        private String b;

        public String getB() {
            return b;
        }

        public void setB(String b) {
            this.b = b;
        }

    }

    public A getA() {
        return a;
    }

    public void setA(A a) {
        this.a = a;
    }

    public static void main(String[] args) {
        Text text = new Text();

        B b = text.new B();
        b.setA("aaaaa");
        b.setB("bbbbb");

        text.setA(b);

        String ttt = JSON.toJSONString(text);
        System.out.println(ttt);
        Text text2 = JSON.parseObject(ttt, Text.class);

        System.out.println(JSON.toJSONString(text2));
    }
    }

这里的输出结果分别是:
{"a":{"a":"aaaaa","b":"bbbbb"}}
{"a":{"a":"aaaaa"}}
在第二次反序列化时候,由于Text对象中A存在继承关系。所以出现信息丢失。请问fastjson中是否有对应的办法解决这个问题?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

冷了相思 2022-09-08 05:11:52

private A a;

改成

private B a;

就可以

倾听心声的旋律 2022-09-08 05:11:52
 SerializerFeature[] features = new SerializerFeature[] {
                SerializerFeature.WriteClassName,
                //SerializerFeature.SkipTransientField,
                //SerializerFeature.DisableCircularReferenceDetect
 };

String ttt = JSON.toJSONString(text, features);
System.out.println(ttt);
Text text2 = JSON.parseObject(ttt, Text.class);

System.out.println(JSON.toJSONString(text2));

子类转父类,泛型等,可以通过WriteClassName这个feature,这样json里会有@type标注真是的类

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文