@JSONField注解

@JSONField来自fastjson

@JSONField

示例代码:

/*
    * name:定义序列化后的属性名
    * ordinal:排序
    * serialize:不序列化此字段
    * deserialize:不反序列化此字段
    * format = "yyyy-MM-dd" : 时间格式处理
    *deserializeUsing = MyDeserializer.class:指定类反序列化
    * serializeUsing = MyDeserializer.class:指定类序列化
    *
    * */
    @JSONField(name="userId",ordinal=0,deserialize = false)
    private Long id;
    class MyDeserializer implements ObjectDeserializer,ObjectSerializer{
 
		@Override
		public <T> T deserialze(DefaultJSONParser parser, Type type,
				Object fieldName) {
			String val = (String) parser.parse();
			return (T) ("aaa " + val);
		}
 
		@Override
		public int getFastMatchToken() {
			// TODO Auto-generated method stub
			return 0;
		}
 
		@Override
		public void write(JSONSerializer serializer, Object object,
				Object fieldName, Type fieldType, int features)
				throws IOException {
			
			serializer.write("aaa " + object);
		}
		
	}

@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方法 } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值