zoukankan      html  css  js  c++  java
  • 定制序列化之@JSONField的使用

    fastjson支持多种方式定制序列化

    • 通过@JSONField定制序列化
    • 通过@JSONType定制序列化
    • 通过SerializeFilter定制序列化
    • 通过ParseProcess定制反序列化

    @JSONField的使用:

    1. 利用@JSONField的format配置日期格式化,这个在上一篇文章有所展示。

    2. 利用@JSONField的serialize指定字段不序列化:

    package com.ant.jdk8.json;
    
    import com.alibaba.fastjson.annotation.JSONField;
    
    import java.util.Date;
    
    public class User {
    
        private String name;
    
        @JSONField(serialize=false)
        private int age;
    
        @JSONField(format="yyyy-MM-dd HH:mm:ss")
        private Date hireDate;
    
        public String getName() {
            return name;
        }
    
        public void setName(String name) {
            this.name = name;
        }
    
        public int getAge() {
            return age;
        }
    
        public void setAge(int age) {
            this.age = age;
        }
    
        public Date getHireDate() {
            return hireDate;
        }
    
        public void setHireDate(Date hireDate) {
            this.hireDate = hireDate;
        }
    
        public User(String name, int age, Date hireDate) {
            this.name = name;
            this.age = age;
            this.hireDate = hireDate;
        }
    
        public User() {
        }
    }
    
    package com.ant.jdk8.json;
    
    import com.alibaba.fastjson.JSON;
    
    import java.util.ArrayList;
    import java.util.Date;
    import java.util.List;
    
    public class JsonDemo {
    
        public static void main(String[] args) {
            convertCollectionToJson();
        }
    
        public static void convertCollectionToJson(){
            List<User> userList = new ArrayList<>();
            userList.add(new User("tom",20,new Date()));
            userList.add(new User("jack",25,new Date()));
            String jsonString = JSON.toJSONString(userList);
            System.out.println(jsonString);
        }
    
    }
    

     3. 利用@JSONField的ordinal指定序列化的顺序(这个特性需要1.1.42以上版本):

    package com.ant.jdk8.json;
    
    import com.alibaba.fastjson.annotation.JSONField;
    
    import java.util.Date;
    
    public class User {
    
        @JSONField(ordinal=3)
        private String name;
    
        @JSONField(ordinal=2)
        private int age;
    
        @JSONField(format="yyyy-MM-dd HH:mm:ss",ordinal = 1)
        private Date hireDate;
    
        public String getName() {
            return name;
        }
    
        public void setName(String name) {
            this.name = name;
        }
    
        public int getAge() {
            return age;
        }
    
        public void setAge(int age) {
            this.age = age;
        }
    
        public Date getHireDate() {
            return hireDate;
        }
    
        public void setHireDate(Date hireDate) {
            this.hireDate = hireDate;
        }
    
        public User(String name, int age, Date hireDate) {
            this.name = name;
            this.age = age;
            this.hireDate = hireDate;
        }
    
        public User() {
        }
    }
    
    package com.ant.jdk8.json;
    
    import com.alibaba.fastjson.JSON;
    
    import java.util.ArrayList;
    import java.util.Date;
    import java.util.List;
    
    public class JsonDemo {
    
        public static void main(String[] args) {
            convertCollectionToJson();
        }
    
        public static void convertCollectionToJson(){
            List<User> userList = new ArrayList<>();
            userList.add(new User("tom",20,new Date()));
            userList.add(new User("jack",25,new Date()));
            String jsonString = JSON.toJSONString(userList);
            System.out.println(jsonString);
        }
    
    }
    

    4. 利用@JSONField的name指定字段的名称:

    package com.ant.jdk8.json;
    
    import com.alibaba.fastjson.annotation.JSONField;
    
    import java.util.Date;
    
    public class User {
    
        @JSONField(ordinal=3,name="username")
        private String name;
    
        @JSONField(ordinal=2)
        private int age;
    
        @JSONField(format="yyyy-MM-dd HH:mm:ss",ordinal = 1)
        private Date hireDate;
    
        public String getName() {
            return name;
        }
    
        public void setName(String name) {
            this.name = name;
        }
    
        public int getAge() {
            return age;
        }
    
        public void setAge(int age) {
            this.age = age;
        }
    
        public Date getHireDate() {
            return hireDate;
        }
    
        public void setHireDate(Date hireDate) {
            this.hireDate = hireDate;
        }
    
        public User(String name, int age, Date hireDate) {
            this.name = name;
            this.age = age;
            this.hireDate = hireDate;
        }
    
        public User() {
        }
    }
    
    package com.ant.jdk8.json;
    
    import com.alibaba.fastjson.JSON;
    
    import java.util.ArrayList;
    import java.util.Date;
    import java.util.List;
    
    public class JsonDemo {
    
        public static void main(String[] args) {
            convertCollectionToJson();
        }
    
        public static void convertCollectionToJson(){
            List<User> userList = new ArrayList<>();
            userList.add(new User("tom",20,new Date()));
            userList.add(new User("jack",25,new Date()));
            String jsonString = JSON.toJSONString(userList);
            System.out.println(jsonString);
        }
    
    }
    

  • 相关阅读:
    CSS3 03. 3D变换、坐标系、透视perspective、transformZ、transform-style添加3D效果、backface-visibility元素背面可见、动画animation、@keyfarmes、多列布局
    CSS3 02. 边框、边框圆角、边框阴影、边框图片、渐变、线性渐变、径向渐变、背景、过渡transition、2D转换(缩放、位移、旋转、倾斜)
    CSS3 01. CSS3现状、属性选择器、伪类选择器、结构伪类、伪元素选择器、颜色、文本阴影shadow、盒子模型、私有化前缀
    HTML5 01. 布局、语义化标签、智能化表单、表单元素/标签/属性/事件、多媒体、类操作、自定义属性
    webstorm 突然不能用了?解决办法~
    jQuery
    jQuery
    jQuery
    JS-特效 ~ 05. 缓动框架兼容封装/回掉函数/兼容透明度/层级、旋转轮播图、正则表达式、验证表单注册账号、
    百问网WIFI模块驱动
  • 原文地址:https://www.cnblogs.com/i-hard-working/p/9221254.html
Copyright © 2011-2022 走看看