4

私はこのオブジェクトのツリーを持っています

B は A を拡張します

C は B を拡張します

DはBを拡張します

E は C を拡張します

F は A を拡張し、A への 1 つの参照を持ちます

A には次の注釈があります

@JsonTypeInfo(use=JsonTypeInfo.Id.CLASS,include=JsonTypeInfo.As.PROPERTY,property="@class")

A を拡張するオブジェクトの JSON 配列を逆シリアル化しようとすると、次のエラーがスローされます

org.codehaus.jackson.map.JsonMappingException: 予期しないトークン (START_OBJECT)、予想される VALUE_STRING: タイプ ID を含む JSON 文字列が必要です (java.util.Collection のサブタイプ用)

json 文字列はセットの toString() メソッドによって生成され、セットは型 A にパラメトリックであり、A は次のコードを使用して JSON でシリアル化されます。

ObjectMapper objectMapper=new ObjectMapper();
        objectMapper.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_CONCRETE_AND_ARRAYS);
        String res="";
        try {
            res = objectMapper.writerWithDefaultPrettyPrinter().writeValueAsString(t);
        } catch (JsonGenerationException e) {
            e.printStackTrace();
        } catch (JsonMappingException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }
        return res;

json 配列 (上記のセット) を逆シリアル化するコードは次のとおりです。

ObjectMapper mapper = new ObjectMapper(); 

        mapper.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_CONCRETE_AND_ARRAYS);
        Collection<T> results=null;
        try {
            results =  mapper.readValue(json, TypeFactory.defaultInstance().constructParametricType(Collection.class, clazz ) );
        } catch (JsonParseException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (JsonMappingException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }  
        return results;

解析する json サンプルは次のようになります。

"[{
  "@class" : "pack1.pack2.MyClass",
  "id" : null,
  "f1" : "",
  "f2" : 0.9933817827,
  "f3" : 6.883261E-4,
  "f4" : 0.001375699,
  "f5" : {
    "@class" : "pack1.pack2.MyClass2",
    "id" : null,
    "f1" : "",
    "f2" : 0.0,
    "f3" : 0.0,
    "f4" : 0.0,
    "f5" : [ "java.util.HashSet", [ 0 ] ],
    "f6" : [ "java.util.HashSet", [ 2 ] ],
    "f7" : [ "java.util.ArrayList", [ "scelta", "brani", "buona" ] ],
    "f8" : [ null, "NOM", null ],
    "f9" : false
  },
  "f10" : [ "java.util.HashMap", {
    "2" : "ADJ"
  } ],
  "f11" : [ "java.util.HashSet", [ 0 ] ],
  "f12" : [ "java.util.HashSet", [ 2 ] ],
  "f13" : [ "java.util.ArrayList", [ "scelta", "brani", "buona" ] ],
  "featureIndicator" : false
}]"

ここで、json 文字列には、Java Set のサンプルの一部のオブジェクトのみが含まれています

4

1 に答える 1

2

問題はデフォルトのタイピングにあると思います。JSON の開始は、Jackson がデフォルトの入力で期待するようには生成されません。JSON の先頭は次のようになります。

["java.util.HashSet", [{

最後に追加の閉じ括弧が必要}]]です。

toString()これは、セットのメソッドを使用して JSON を生成するためです。代わりにObjectMapper、次のように、デフォルトの入力で構成されている を使用する必要があります。

res = objectMapper.writerWithDefaultPrettyPrinter().writeValueAsString(yourSet);
于 2013-04-05T15:36:41.257 に答える