fastjson对Date的处理

fastjson对日期的序列化方式

一种方法是通过注解

1
2
@JSONField (format="yyyy-MM-dd HH:mm:ss")
public Date birthday;

另一种是通过SerializeConfig:

1
2
3
4
5
6
private static SerializeConfig mapping = new SerializeConfig();
private static String dateFormat;
static {
dateFormat = "yyyy-MM-dd HH:mm:ss";
mapping.put(Date.class, new SimpleDateFormatSerializer(dateFormat));
}

json字符串中使用单引号:

1
String text = JSON.toJSONString(object, SerializerFeature.UseSingleQuotes);

字段显示不同的key:

1
2
3
4
5
6
7
public class User {
@JSONField(name="ID")
public int getId() { ... }
}

User user = ...;
JSON.toJSONString(user); // {"ID":001}

类的反序列化 JavaBean:

1
2
String text = ...; // {"r":255,"g":0,"b":0,"alpha":255}
Color color = JSON.parseObject(text, Color.class);

数组:

1
2
String text = ...; // [{ ... }, { ... }]
List<User> users = JSON.parseArray(text, User.class);

泛型:

1
2
String text = ...; // {"name":{"name":"ljw",age:18} }
Map<String, User> userMap = JSON.parseObject(text, new TypeReference<Map<String, User>>() {});

自定义序列化代码示例

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
public class JsonUtil {
private static SerializeConfig mapping = new SerializeConfig();
private static String dateFormat;
static {
dateFormat = "yyyy-MM-dd HH:mm:ss";
}

/**
* 默认的处理时间
*
* @param jsonText
* @return
*/
public static String toJSON(Object jsonText) {
return JSON.toJSONString(jsonText,
SerializerFeature.WriteDateUseDateFormat);
}

/**
* 自定义时间格式
*
* @param jsonText
* @return
*/
public static String toJSON(String dateFormat, String jsonText) {
mapping.put(Date.class, new SimpleDateFormatSerializer(dateFormat));
return JSON.toJSONString(jsonText, mapping);
}
}

自定义日期格式反序列化示例

先自定义一个日期解析类:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
public class MyDateFormatDeserializer extends DateFormatDeserializer {

private String myFormat;

public MyDateFormatDeserializer(String myFormat) {
super();
this.myFormat = myFormat;
}

@Override
protected <Date> Date cast(DefaultJSONParser parser, Type clazz, Object fieldName, Object val) {
if (myFormat == null) {
return null;
}
if (val instanceof String) {
String strVal = (String) val;
if (strVal.length() == 0) {
return null;
}

try {
return (Date) new SimpleDateFormat(myFormat).parse((String)val);
} catch (ParseException e) {
throw new JSONException("parse error");
}
}
throw new JSONException("parse error");
}
}

User类

1
2
3
4
5
6
7
8
9
10
11
12
13
public class User {

public String name;
public int height;

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

@JSONField(format = "yyyy-MM/dd HH:mm:ss")
public Date birthday;
}

测试如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
/**
* @param args
* @throws IOException
*/
public static void main(String[] args) throws IOException, ParseException {

String json = "{\"name\":\"22323\", \"age\": 1234," +
" \"birthday\": \"2012-12/12 12:12:12\"}";
Test t = JSON.parseObject(json, Test.class, mapping,
JSON.DEFAULT_PARSER_FEATURE, new Feature[0]);
System.out.println(t.name);
System.out.println(t.height);
System.out.println(t.birthday);
System.out.println(
new SimpleDateFormat("yyyy-MM/dd HH:mm:ss").parse("2012-12/12 12:12:12"));
}

总结

对于JSONField注解,好像只对序列号的格式有影响,反序列化不管这个,不知道为什么, 只能自己写个解析类了,不过这样就更灵活了,可以在里面写很多处理逻辑, 比如json字符串里面日期格式并不是标准格式的时候,就可以先转成标准格式再去解析了。