@JSONField注解的使用

@JSONField注解可以用在方法(method),属性(field)以及方法中的参数(parameter)上。JSONField中的name属性用来指定JSON串中key的名称。

Demo:

@JSONField作用在Field时,其name不仅定义了输入key的名称,同时也定义了输出的名称。
public class Person {
    @JSONField(name = "name") // 注意观察生成的JSON串中name和age的区别
    private String name;
    @JSONField(name = "AGE")
    private String age;

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getAge() {
        return age;
    }

    public void setAge(String age) {
        this.age = age;
    }
}

@JSONField也可以直接作用在get或set方法上
@JSONField(name = "name")
public String getName() {
    return name;
}

@JSONField(name = "name")
public void setName(String name) {
    this.name = name;
}

@JSONField(name = "AGE")
public String getAge() {
    return age;
}

@JSONField(name = "AGE")
public void setAge(String age) {
    this.age = age;
}

PS:FastJson在进行操作时,是根据getter和setter的方法进行的,并不是依据Field进行。
public class PersonTest {
    private Person person;

    /**
    * 初始化对象
    */
    @Before
    public void setUp() {
        person = new Person();
        person.setName("gyl");
        person.setAge("20");
    }

    @Test
    public void test() {
        String jsonStr = JSONObject.toJSONString(person);
        System.out.println("bean to json:" + jsonStr);
        person = JSONObject.toJavaObject(JSONObject.parseObject(jsonStr), Person.class);
        System.out.println("json to bean:" + person.getName());
    }
}
Output:
bean to json:{"AGE":"20","name":"gyl"}
json to bean:gyl

JSONField默认支持的类型

public @interface JSONField {
    int ordinal() default 0;

    String name() default "";

    String format() default "";

    boolean serialize() default true;

    boolean deserialize() default true;

    SerializerFeature[] serialzeFeatures() default {};

    Feature[] parseFeatures() default {};

    String label() default "";

    boolean jsonDirect() default false;

    Class<?> serializeUsing() default Void.class;

    Class<?> deserializeUsing() default Void.class;

    String[] alternateNames() default {};

    boolean unwrapped() default false;
}

format规定日期格式

@JSONField(format="yyyy-MM-dd HH:mm:ss")
private Date date;

ordinal规定字段的顺序

@JSONField(ordinal = 3)
private int f0;

@JSONField(ordinal = 2)
private int f1;

@JSONField(ordinal = 1)
private int f2;
fastjson序列化⼀个java bean,是根据fieldName的字母序进⾏序列的你可以通过ordinal指定字段的顺序。

serialize/deserialize指定字段不序列化

@JSONField(serialize=false)
public Date date;
  • 37
    点赞
  • 170
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
@JSONField注解是阿里巴巴的fastjson库提供的一个注解,用于控制Java对象与JSON字符串之间的转换。它可以用于修饰Java对象的属性,指定属性在序列化和反序列化过程中的行为。 @JSONField注解的作用有以下几个方面: 1. 控制属性的序列化和反序列化:通过设置@JSONField注解的serialize和deserialize属性,可以指定属性在序列化和反序列化过程中的行为。例如,可以设置serialize=false来禁止属性的序列化,或者设置deserialize=false来禁止属性的反序列化。 2. 指定属性的名称:通过设置@JSONField注解的name属性,可以指定属性在JSON字符串中的名称。默认情况下,属性的名称与Java对象的属性名一致,但通过设置name属性,可以自定义属性的名称。 3. 控制属性的顺序:通过设置@JSONField注解的ordinal属性,可以指定属性在JSON字符串中的顺序。默认情况下,属性的顺序与Java对象中的属性定义顺序一致,但通过设置ordinal属性,可以调整属性的顺序。 4. 格式化日期类型属性:通过设置@JSONField注解的format属性,可以指定日期类型属性在序列化和反序列化过程中的格式。例如,可以设置format="yyyy-MM-dd"来指定日期类型属性的格式为年-月-日。 下面是一个使用@JSONField注解的示例: ```java public class User { @JSONField(name = "id") private int userId; @JSONField(name = "name") private String userName; @JSONField(format = "yyyy-MM-dd") private Date birthday; // 省略getter和setter方法 } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值