Jackson處理一般的JavaBean和Json之間的轉換只要使用ObjectMapper 對象的readValue和writeValueAsString兩個方法就能實現。
假設一個List<A>的對象被序列化為一個json,如果采用如下方式:
{code}List<A> aList = new ArrayList<A>;
objectMapper.readValue(json,aList.class);{code}
如上的反序列化方式,雖然能夠成功,但是A類型實際上會被反序列化為一個HashMap對象。
如果要轉換復雜類型Collection如 List<YourBean>,那么就需要先反序列化復雜類型 為泛型的Collection Type。
如果是ArrayList<YourBean>那么使用ObjectMapper 的getTypeFactory().constructParametricType(collectionClass, elementClasses);
如果是HashMap<String,YourBean>那么 ObjectMapper 的getTypeFactory().constructParametricType(HashMap.class,String.class, YourBean.class);
public final ObjectMapper mapper = new ObjectMapper(); public static void main(String[] args) throws Exception{ JavaType javaType = getCollectionType(ArrayList.class, YourBean.class); List<YourBean> lst = (List<YourBean>)mapper.readValue(jsonString, javaType); } /** * 獲取泛型的Collection Type * @param collectionClass 泛型的Collection * @param elementClasses 元素類 * @return JavaType Java類型 * @since 1.0 */ public static JavaType getCollectionType(Class<?> collectionClass, Class<?>... elementClasses) { return mapper.getTypeFactory().constructParametricType(collectionClass, elementClasses); }
拷貝至: http://www.cnblogs.com/quanyongan/archive/2013/04/16/3024993.html
詳細:http://hw1287789687.iteye.com/blog/2228897
方法二:
最近使用了jackson json來格式化數據輸出,但是反序列化生成對象的時候碰到點麻煩,jackson把數據默認解析成了Map對象,經查詢文檔,問題解決,在ObjectMapper的readvalue方法中按Object所使用的類型聲明即可,代碼如下:
Map<Integer, RbtCounter> srcMap = new LinkedHashMap();
Map<Integer, RbtCounter> destMap;
String jsonData = mapper.writeValueAsString(srcMap);
正確:
import org.codehaus.jackson.type.TypeReference;
destMap = mapper.readValue(jsonData, new TypeReference<Map<Integer, RbtCounter>>(){});
錯誤
destMap = mapper.readValue(jsonData, LinkedHashMap.class);
List中的自定義Object同理解決。