10

このような構造を考えると:

{
  "nameOfObject": { "score": 100 },
  "anotherObject": { "score": 30 }
}

これを次のようにマッピングすることは可能ですか:

class Container {
  Map<String, ScoreKeeper> scoreKeepers;
}

class ScoreKeeper {
  String name;
  int score;
}

インスタンスのnameプロパティをそれぞれおよびに設定することになりますか?ScoreKeeper"nameOfObject""anotherObject"

4

3 に答える 3

4

私は、POJO を外部化から分離することを固く信じています。JSON を Map に読み込んでから、次のように Container/ScoreKeeper オブジェクトを構築します (タイプミスの apols):

mapper = new ObjectMapper();

Map<String,Object> data = mapper.readValue(inputstream, Map.class);

Container c = new Container();

for(Map.Entry<String, Object> me : data.entrySet()) {
    String key = me.getKey();
    Map info = (Map) me.getValue();

    ScoreKeeper sk = new ScoreKeeper();
    sk.setName(key);
    Integer q = info.get("score");
    sk.setScore(q);

    c.put(key, sk);
}
于 2013-10-08T15:26:29.057 に答える
3

nameカスタム デシリアライザーを使用して値オブジェクトにキーを設定する代替ソリューション:

@Test
public void test() throws JsonParseException, JsonMappingException, IOException {
    ObjectMapper mapper = new ObjectMapper();

    Data data = mapper.readValue("{\"users\": {\"John\": {\"id\": 20}, \"Pete\": {\"id\": 30}}}", Data.class);

    assertEquals(20, data.users.get("John").id);
    assertEquals(30, data.users.get("Pete").id);
    assertEquals("John", data.users.get("John").name);
    assertEquals("Pete", data.users.get("Pete").name);
}

public static class Data {
    @JsonDeserialize(contentUsing = Deser.class)
    public Map<String, User> users;
}

public static class User {
    public String name;
    public int id;
}

public static class Deser extends JsonDeserializer<User> {

    @Override
    public User deserialize(JsonParser p, DeserializationContext ctxt) throws IOException, JsonProcessingException {
        String name = ctxt.getParser().getCurrentName();

        User user = p.readValueAs(User.class);

        user.name = name;  // This copies the key name to the value object

        return user;
    }
}
于 2017-03-13T14:55:39.023 に答える