Вопрос

Я хочу иметь возможность доступа к свойствам из строки JSON в моем методе Java action.Строка доступна, просто сказав myJsonString = object.getJson().Ниже приведен пример того, как может выглядеть строка:

{
    'title': 'ComputingandInformationsystems',
    'id': 1,
    'children': 'true',
    'groups': [{
        'title': 'LeveloneCIS',
        'id': 2,
        'children': 'true',
        'groups': [{
            'title': 'IntroToComputingandInternet',
            'id': 3,
            'children': 'false',
            'groups': []
        }]
    }]
}

В этой строке каждый объект JSON содержит массив других объектов JSON.Цель состоит в том, чтобы извлечь список идентификаторов, в которых любой данный объект, обладающий групповым свойством, содержит другие объекты JSON.Я рассматривал Google Gson как потенциальный JSON-плагин.Кто-нибудь может предложить какую-то форму руководства относительно того, как я могу сгенерировать Java из этой строки JSON?

Это было полезно?

Решение

Я рассматривал Google Gson как потенциальный JSON-плагин.Кто-нибудь может предложить какую-то форму руководства относительно того, как я могу сгенерировать Java из этой строки JSON?

Google Gson поддерживает дженерики и вложенные компоненты.В [] в JSON представляет собой массив и должен сопоставляться с коллекцией Java, такой как List или просто обычный Java-массив.В {} в JSON представляет объект и должен сопоставляться с Java Map или просто какой-нибудь JavaBean-класс.

У вас есть объект JSON с несколькими свойствами, из которых groups свойство представляет собой массив вложенных объектов одного и того же типа.Это может быть проанализировано с помощью Gson следующим образом:

package com.stackoverflow.q1688099;

import java.util.List;
import com.google.gson.Gson;

public class Test {

    public static void main(String... args) throws Exception {
        String json = 
            "{"
                + "'title': 'Computing and Information systems',"
                + "'id' : 1,"
                + "'children' : 'true',"
                + "'groups' : [{"
                    + "'title' : 'Level one CIS',"
                    + "'id' : 2,"
                    + "'children' : 'true',"
                    + "'groups' : [{"
                        + "'title' : 'Intro To Computing and Internet',"
                        + "'id' : 3,"
                        + "'children': 'false',"
                        + "'groups':[]"
                    + "}]" 
                + "}]"
            + "}";

        // Now do the magic.
        Data data = new Gson().fromJson(json, Data.class);

        // Show it.
        System.out.println(data);
    }

}

class Data {
    private String title;
    private Long id;
    private Boolean children;
    private List<Data> groups;

    public String getTitle() { return title; }
    public Long getId() { return id; }
    public Boolean getChildren() { return children; }
    public List<Data> getGroups() { return groups; }

    public void setTitle(String title) { this.title = title; }
    public void setId(Long id) { this.id = id; }
    public void setChildren(Boolean children) { this.children = children; }
    public void setGroups(List<Data> groups) { this.groups = groups; }

    public String toString() {
        return String.format("title:%s,id:%d,children:%s,groups:%s", title, id, children, groups);
    }
}

Довольно просто, не правда ли?Просто найдите подходящий JavaBean и вызовите Gson#fromJson().

Смотрите также:

Другие советы

Беваааааре из Gson!Это очень круто, очень здорово, но в ту секунду, когда вы захотите сделать что-то другое, кроме простых объектов, вам может легко понадобиться начать создавать свои собственные сериализаторы (что не это жесткий).

Кроме того, если у вас есть массив объектов, и вы десериализуете некоторый json в этот массив объектов, истинные типы ТЕРЯЮТСЯ!Полные объекты даже не будут скопированы!Используйте XStream..Который, при использовании jsondriver и установке правильных настроек, будет кодировать уродливые типы в фактический json, так что вы ничего не потеряете.Небольшая цена (уродливый json) за истинную сериализацию.

Обратите внимание , что Джексон устраняет эти проблемы и является быстрее чем GSON.

Как ни странно, единственным приличным процессором JSON, упомянутым до сих пор, был GSON.

Вот еще несколько хороших вариантов:

  • Джексон (Гитхаб) -- мощная привязка данных (JSON к / из POJOs), потоковая передача (сверхбыстрая), древовидная модель (удобная для нетипизированного доступа)
  • Гибкий-JSON -- высоко настраиваемая сериализация

РЕДАКТИРОВАТЬ (август / 2013):

Еще один момент для рассмотрения:

  • Генсон -- функциональность, аналогичная Jackson, предназначенная для упрощения настройки разработчиком

Или с Джексоном:

String json = "...
ObjectMapper m = new ObjectMapper();
Set<Product> products = m.readValue(json, new TypeReference<Set<Product>>() {});

Если в результате какого-либо изменения вы находитесь в приложении, которое уже использует http://restfb.com/ тогда вы можете сделать:

import com.restfb.json.JsonObject;

...

JsonObject json = new JsonObject(jsonString);
json.get("title");

и т.д.

Если вы используете какие-либо специальные карты с ключами или значениями также специальных карт, вы обнаружите, что это не предусмотрено реализацией Google.

Простой и работающий java-код для преобразования JSONObject Для Java Object

Employee.java

import java.util.HashMap;
import java.util.Map;

import javax.annotation.Generated;

import com.fasterxml.jackson.annotation.JsonAnyGetter;
import com.fasterxml.jackson.annotation.JsonAnySetter;
import com.fasterxml.jackson.annotation.JsonIgnore;
import com.fasterxml.jackson.annotation.JsonInclude;
import com.fasterxml.jackson.annotation.JsonProperty;
import com.fasterxml.jackson.annotation.JsonPropertyOrder;

@JsonInclude(JsonInclude.Include.NON_NULL)
@Generated("org.jsonschema2pojo")
@JsonPropertyOrder({
"id",
"firstName",
"lastName"
})
public class Employee {

@JsonProperty("id")
private Integer id;
@JsonProperty("firstName")
private String firstName;
@JsonProperty("lastName")
private String lastName;
@JsonIgnore
private Map<String, Object> additionalProperties = new HashMap<String, Object>();

/**
*
* @return
* The id
*/
@JsonProperty("id")
public Integer getId() {
return id;
}

/**
*
* @param id
* The id
*/
@JsonProperty("id")
public void setId(Integer id) {
this.id = id;
}

/**
*
* @return
* The firstName
*/
@JsonProperty("firstName")
public String getFirstName() {
return firstName;
}

/**
*
* @param firstName
* The firstName
*/
@JsonProperty("firstName")
public void setFirstName(String firstName) {
this.firstName = firstName;
}

/**
*
* @return
* The lastName
*/
@JsonProperty("lastName")
public String getLastName() {
return lastName;
}

/**
*
* @param lastName
* The lastName
*/
@JsonProperty("lastName")
public void setLastName(String lastName) {
this.lastName = lastName;
}

@JsonAnyGetter
public Map<String, Object> getAdditionalProperties() {
return this.additionalProperties;
}

@JsonAnySetter
public void setAdditionalProperty(String name, Object value) {
this.additionalProperties.put(name, value);
}

}

LoadFromJSON.java

import org.codehaus.jettison.json.JSONObject;

import com.fasterxml.jackson.databind.ObjectMapper;

public class LoadFromJSON {

    public static void main(String args[]) throws Exception {
        JSONObject json = new JSONObject();
        json.put("id", 2);
        json.put("firstName", "hello");
        json.put("lastName", "world");

        byte[] jsonData = json.toString().getBytes();

        ObjectMapper mapper = new ObjectMapper();
        Employee employee = mapper.readValue(jsonData, Employee.class);

        System.out.print(employee.getLastName());

    }
}
HashMap keyArrayList = new HashMap();
Iterator itr = yourJson.keys();
while (itr.hasNext())
{
    String key = (String) itr.next();
    keyArrayList.put(key, yourJson.get(key).toString());
}

Что не так со стандартными материалами?

JSONObject jsonObject = new JSONObject(someJsonString);
JSONArray jsonArray = jsonObject.getJSONArray("someJsonArray");
String value = jsonArray.optJSONObject(i).getString("someJsonValue");

Дайте буну попробовать:

https://github.com/RichardHightower/boon

Это ужасно быстро:

https://github.com/RichardHightower/json-parsers-benchmark

Не верьте мне на слово...посмотрите на бенчмарк Гатлинга.

https://github.com/gatling/json-parsers-benchmark

(В некоторых случаях до 4 раз, и из 100 тестов.Он также имеет режим наложения индекса, который работает еще быстрее.Он молод, но у него уже есть несколько пользователей.)

Он может преобразовывать JSON в карты и списки быстрее, чем любая другая библиотека может преобразовывать в JSON DOM, и это без режима наложения индекса.С режимом наложения индекса Boon это делается еще быстрее.

Он также имеет очень быстрый режим JSON lax и режим синтаксического анализа PLIST.:) (и имеет сверхнизкий объем памяти, прямо из байтового режима с кодировкой UTF-8 "на лету").

Он также имеет самый быстрый режим JSON для JavaBean.

Это новинка, но если скорость и простой API - это то, что вы ищете, я не думаю, что существует более быстрый или минималистичный API.

В зависимости от входного формата JSON (строка/ файл) создайте jsonString.Пример объекта класса сообщений, соответствующего JSON, может быть получен следующим образом:

Сообщение msgFromJSON = new ObjectMapper().Значение чтения(jsonString, Message.class);

Самый простой способ заключается в том, что вы можете использовать этот метод softconvertvalue, который является пользовательским методом, с помощью которого вы можете преобразовать jsonData в ваш конкретный класс Dto.

Dto response = softConvertValue(jsonData, Dto.class);


public static <T> T softConvertValue(Object fromValue, Class<T> toValueType) 
{
    ObjectMapper objMapper = new ObjectMapper();
    return objMapper
        .configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false)
        .convertValue(fromValue, toValueType);
}
Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top