附ObjectMapper的API:http://tool.oschina.net/uploads/apidocs/jackson-1.9.9/org/codehaus/jackson/map/ObjectMapper.html
讲解的比较好的一个博文:http://www.cnblogs.com/hoojo/archive/2011/04/22/2024628.html
ObjectMapper是一个高效转化json格式数据的类,如果创建的是spring boot项目,会自动导入com.fasterxml.jackson 依赖包,我使用的是这个类ObjectMapper。
maven依赖:
com.fasterxml.jackson.core
jackson-databind
2.8.3
ObjectMapper:分为解析json格式数据和构建json格式数据。
1.写:
⒈将内容转成json格式然后输出到指定流。(OutputStream or Writer)
objectMapper.writeValue(OutputStream out, Object value); void
⒉将Bean转成byte数组。是使用平台默认的字符串进行编码的,比如中国地区默认的字符集为GBK。在操作中发现GBK,UTF-8,ISO8859-1都能解析这个byte[]
objectMapper.writeValueAsBytes(Object value); byte []
⒊将json数据写入到指定的文件中
File result = new File("d://writeJson.txt");
//1.文件没有创建,会自动创建该文件
//2.文件已经存在,会覆盖掉原先的内容。
om.writeValue(result, obj);
2.读
读取byte数组,转化成对应valueType类型的对象
om.readValue(byte [] src,Class valueType)
//对应byte数组的开始位置和长度做一个限制,然后转化成对应valueType类型的对象
//读取File文件中的内容,转化成对应valueType类型的对象
om.readValue(File src, Class valueType)
//读取流中的内容,转化成对应valueType类型的对象
//读取流中的内容,转化成对应valueType类型的对象
om.readValue(Reader src, Class valueType)
//读取字符串,转成对应的valueType类型的对象
一般情况下用的比较多是om.readValue(String content, Class valueType)
类型可以是List Map Set 数组 或者是普通的Bean,但如果要转换成的类型是List<Person>类型,会出现转换错误ClassCastException,ObjectMapper在转化List时,返回的是List<LinkedHashMap> ,因为任何对象都可以用Map来表示。
List listP = (List) om.readValue(str, s);
log.info("type:"+listP.get(0).getClass());
返回// type:class java.util.LinkedHashMap
下面是在网上看的一些问题
在转化过程中需要注意的问题:
有可能会遇到json反序列化的问题。当你对象中有get***()的地方,它就当做它是一个属性,所以当你序列化json之后,在反序列化的时候,很有可能会出现异常的情况,因为在你的model中没有这个属性的定义。
那该如何处理和解决呢?
jackson给出了它自己的解决方案(JacksonHowToIgnoreUnknow):
1. 在class上添加忽略未知属性的声明:@JsonIgnoreProperties(ignoreUnknown=true)
2. 在反序列化中添加忽略未知属性解析,如下:
1 /**
2 * json deserialize
3 * @param json
4 * @param mapClazz
5 * @return
6 */
7 public static Object jsonDeserialize(final String json, final Class<?> mapClazz) {
8 ObjectMapper om = new ObjectMapper();
9 try {
10 // 忽略未知属性
11 om.configure(DeserializationConfig.Feature.FAIL_ON_UNKNOWN_PROPERTIES, false);
12 return om.readValue(json, mapClazz);
13 } catch (Exception ex) {
14 return null;
15 }
16 }
3. 添加"Any setter"来处理未知属性
1 // note: name does not matter; never auto-detected, need to annotate
2 // (also note that formal argument type #1 must be "String"; second one is usually
3 // "Object", but can be something else -- as long as JSON can be bound to that type)
4 @JsonAnySetter
5 public void handleUnknown(String key, Object value) {
6 // do something: put to a Map; log a warning, whatever
7 }
⒋ 注册问题处理句柄
注册一个DeserializationProblemHandler句柄,来调用ObjectMapper.addHandler()。当添加的时候,句柄的handleUnknownProperty方法可以在每一个未知属性上调用一次。
这个方法在你想要添加一个未知属性处理日志的时候非常有用:当属性不确定的时候,不会引起一个绑定属性的错误。
jackJson也支持处理xml格式数据,使用的是:
XmlMapper xml = new XmlMapper();