0

我有一些以下格式的 JSON,我试图用杰克逊解析 -

"response":{
"response_inner":{
"a":{"field1":2,"field2":0,"field3":5,"field4":0,"field5":[{"field5_1":"b","field5_2":1},{"field5_1":"c","field5_2":1}]},
"d":{"field1":2,"field2":6,"field3":11,"field4":0,"field5":[{"field5_1":"c","field5_2":1},{"field5_1":"b","field5_2":1}]},
"response_inner_bool":false
}
}

这里的“a”、“b”等是一些可以在每个响应中改变的字符串。

我创建了一个 Java 对象来表示“response_inner”(我们称之为 ResponseInner)和另一个来表示包含该字段的对象(我们称之为 FieldInfo),但我不确定如何使用 @ 解析它JsonCreator 和 @JsonProperty 注释 - ResponseInner 对象可以包含任意数量的 String -> FieldInfo 映射。

我试着像这样解析它 -

public class Response {
    private ResponseInner responseInner;

    @JsonCreator
    public Response(@JsonProperty("response_inner") ResponseInner responseInner) {
        this.reponseInner = responseInner;
    }
}

public class ResponseInner {
    private Map<String, FieldInfo> stringToFieldInfoMap;
    private boolean responseInnerBool;

    @JsonCreator
    public ResponseInner(Map<String, FieldInfo> stringToFieldInfoMap, @JsonProperty("response_inner_bool") boolean responseInnerBool ) {
        this.stringToFieldInfoMap = stringToFieldInfoMap;
        this.responseInnerBool = responseInnerBool;
    }
}

但它抱怨构造函数的参数 #0 没有属性名称注释;当多参数构造函数注释为 Creator 时必须有名称。关于如何解决这个问题的任何建议?

4

1 回答 1

0

无论如何,您似乎都没有使用stringToFieldInfoMapinside ResponseInner 。为什么需要将其作为参数传递?

如果您在该类中确实需要它,您可以简单地通过 setter 设置它,而不是将其传递给构造函数。

或者,您也许可以利用第三个类来处理响应的实际映射,该映射使用 Response 对象(这反过来又会使用已从中删除 Map 的 ResponseInner 对象)。这实际上可能允许您将映射逻辑与响应逻辑分离。

public class MappedResponse {
    private Map<String, FieldInfo> stringToFieldInfoMap;
    private Response response;

    public MappedResponse(Map<String, FieldInfo> stringToFieldInfoMap, Response response) {
        this.stringToFieldInfoMap = stringToFieldInfoMap;
        this.response = response;     
    }
}
于 2012-12-13T19:58:03.483 回答