java字段不序列化注解_关于数据序列化(5),定制FastJSON序列化(解决Java大Long类型js的Number接收丢失数据的问题,不序列化某些属性)...

1. 指定某个类型序列化

问题描述:

JavaScript使用IEEE 754标准

1位用来表示符号位

11位用来表示指数

52位表示尾数

javaScript对于整形只能识别52位。遇到Long大整数可能会丢失数据

因为后台是Java写的难免有属性的类型是long。本来项目的做法是手动写每个类的toString();方法要拼接很多双引号。比较费劲也容易出错。

后来我使用了FastJson定制序列化遇到Long就写字符串来解决返回给客户端的JSON。

主要代码如下:

定制Long类型的序列化

public final static SerializeConfig resultJsonConfig = new SerializeConfig();

static{

resultJsonConfig.put(Long.class,new ObjectSerializer() {

@Override

public void write(JSONSerializer serializer,Object object,Object fieldName,Type fieldType,int features)

throws IOException {

SerializeWriter out = serializer.getWriter();

out.writeString(Objects.toString(object,null));

}

});

}

使用:

protected String getResult(T value) {

JSONObject json = new JSONObject();

json.put("state",state.getState());

json.put("desc",state.getDesc());

json.put("value",value);

return JSON.toJSONString(json,resultJsonConfig,SerializerFeature.DisableCircularReferenceDetect);

}

2.如果要让这个策略全局生效

SerializeConfig.getGlobalInstance().put(Long.class,int features)

throws IOException {

SerializeWriter out = serializer.getWriter();

if (fieldType == long.class || fieldType == Long.class) {

out.writeString(Objects.toString(object,null));

}

// if (numberValue == null) {

// if (out.isEnabled(SerializerFeature.WriteNullNumberAsZero)) {

// out.write('0');

// } else {

// out.writeNull();

// }

// return;

// }

}

});

2. 对某些属性不序列化

2.1 定义一个注解

@Retention(RetentionPolicy.RUNTIME)

@Target({ElementType.FIELD})

public @interface ResultNotSerialize {

}

2.2 将注解加在属性上

public class MemberVO {

private String memberId;

private String memberName;

@ResultNotSerialize

private String password;

2.3 定义一个过滤器

public static final PropertyFilter controllerResultJsonFilter = new PropertyFilter() {

@Override

public boolean apply(Object object,String key,Object value) {

try {

Field field = object.getClass().getDeclaredField(key);

if(null !=field && null != field.getAnnotation(ResultNotSerialize.class)){

return false;

}

return true;

} catch (Exception e) {

return true;

}

}

};

2.4 如何使用

SON.toJSONString(obj,controllerResultJsonFilter);

3. Java长ID,js接收丢失数据问题最终的解决办法

@Retention(RetentionPolicy.RUNTIME)

@Target({ElementType.FIELD})

public @interface SerializeAsSting {

}

public class MemberVO {

@SerializeAsSting

private Long id = 0L;//long type id

public static final PropertyFilter resultJsonPropertyFilter = new PropertyFilter() {

@Override

public boolean apply(Object object,Object value) {

try {

Field field = object.getClass().getDeclaredField(key);

if (null != field && null != field.getAnnotation(NotSerialize.class)) {

return false;

}

return true;

} catch (Exception e) {

return true;

}

}

};

public static final ValueFilter resultValueFilter = new ValueFilter() {

@Override

public Object process(Object object,String name,Object value) {

// LogCore.BASE.info("object={},name={},value={}",object,name,value);

if(value == null){

return value;

}

try {

Field field = object.getClass().getDeclaredField(name);

if (null != field && null != field.getAnnotation(SerializeAsSting.class)) {

return value.toString();

}

return value;

} catch (Exception e) {

return value;

}

}

};

public final static SerializeFilter[] resultJsonFilters = new SerializeFilter[]{resultJsonPropertyFilter,resultValueFilter};

protected String getResult(ErrorState state,T value) {

JSONObject json = new JSONObject();

json.put("state",state.getState());

json.put("desc",state.getDesc());

json.put("value",value);

return JSON.toJSONString(json,resultJsonFilters,SerializerFeature.WriteMapNullValue,SerializerFeature.DisableCircularReferenceDetect);

}

相关文章

总结

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。

如您喜欢交流学习经验,点击链接加入交流1群:1065694478(已满)交流2群:163560250

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在使用fastjson进行反序列化Java中实体的枚举字段时,如果出现错误,可以检查以下几个方面: 1. 确认枚举类中的枚举值是否能够正确映射。fastjson默认使用枚举值的名称进行序列化和反序列化,因此需要确保枚举值的名称和实际值之间的映射关系正确。 2. 确认实体类中的枚举字段类型是否正确。如果枚举字段类型不是枚举类本身,而是其它类型(如String),则需要使用@JSONField注解来指定fastjson进行序列化和反序列化时应该使用的类型。例如: ``` public class Entity { @JSONField(deserializeUsing = ColorDeserializer.class) private Color color; // ... } ``` 在这个例子中,ColorDeserializer是一个自定义的反序列化器,用于将枚举值的名称转换为枚举对象。在实体类中使用@JSONField注解指定该字段应该使用ColorDeserializer进行反序列化。 3. 如果仍然出现错误,可以尝试使用fastjson的自定义反序列化器来处理枚举字段。例如: ``` public class ColorDeserializer implements ObjectDeserializer { @Override public Color deserialze(DefaultJSONParser parser, Type type, Object fieldName) throws JSONException { String value = parser.getLexer().stringVal(); for (Color color : Color.values()) { if (color.name().equalsIgnoreCase(value)) { return color; } } throw new JSONException("Invalid color value: " + value); } @Override public int getFastMatchToken() { return JSONToken.LITERAL_STRING; } } ``` 然后,在进行反序列化时,可以将ColorDeserializer传递给ParserConfig对象: ``` ParserConfig.getGlobalInstance().putDeserializer(Color.class, new ColorDeserializer()); ``` 这样,fastjson就会使用ColorDeserializer来处理枚举字段的反序列化

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值