Подтвердить что ты не робот

Преобразование строки JSON в Pretty Print Выход JSON с использованием Jackson

У меня есть строка JSON:

{"attributes":[{"nm":"ACCOUNT","lv":[{"v":{"Id":null,"State":null},"vt":"java.util.Map","cn":1}],"vt":"java.util.Map","status":"SUCCESS","lmd":13585},{"nm":"PROFILE","lv":[{"v":{"Party":null,"Ads":null},"vt":"java.util.Map","cn":2}],"vt":"java.util.Map","status":"SUCCESS","lmd":41962}]}

Мне нужно преобразовать вышеуказанный JSON String в вывод JSON Pretty Print (используя Джексона), как показано ниже:

{
    "attributes": [
        {
            "nm": "ACCOUNT",
            "lv": [
                {
                    "v": {
                        "Id": null,
                        "State": null
                    },
                    "vt": "java.util.Map",
                    "cn": 1
                }
            ],
            "vt": "java.util.Map",
            "status": "SUCCESS",
            "lmd": 13585
        },
        {
            "nm": "PROFILE
            "lv": [
                {
                    "v": {
                        "Party": null,
                        "Ads": null
                    },
                    "vt": "java.util.Map",
                    "cn": 2
                }
            ],
            "vt": "java.util.Map",
            "status": "SUCCESS",
            "lmd": 41962
        }
    ]
}

Может ли кто-нибудь предоставить мне пример, основанный на моем примере выше? Как добиться этого сценария? Я знаю, что примеров много, но я не могу их правильно понять. Любая помощь будет оценена на простом примере.

Обновлено:

Ниже приведен код, который я использую:

ObjectMapper mapper = new ObjectMapper();
System.out.println(mapper.defaultPrettyPrintingWriter().writeValueAsString(jsonString));

Но это не работает так, как мне нужно, как указано выше.

Вот POJO, который я использую для вышеуказанного JSON:

public class UrlInfo implements Serializable {

    private List<Attributes> attribute;

}

class Attributes {

    private String nm;
    private List<ValueList> lv;
    private String vt;
    private String status;
    private String lmd;

}


class ValueList {
    private String vt;
    private String cn;
    private List<String> v;
}

Может кто-нибудь сказать мне, получил ли я правильный POJO для JSON или нет?

Обновлено:

String result = restTemplate.getForObject(url.toString(), String.class);

ObjectMapper mapper = new ObjectMapper();
Object json = mapper.readValue(result, Object.class);

String indented = mapper.defaultPrettyPrintingWriter().writeValueAsString(json);

System.out.println(indented);//This print statement show correct way I need

model.addAttribute("response", (indented));

Ниже строки напечатано что-то вроде этого:

System.out.println(indented);


{
  "attributes" : [ {
    "nm" : "ACCOUNT",
    "error" : "null SYS00019CancellationException in CoreImpl fetchAttributes\n java.util.concurrent.CancellationException\n\tat java.util.concurrent.FutureTask$Sync.innerGet(FutureTask.java:231)\n\tat java.util.concurrent.FutureTask.",
    "status" : "ERROR"
  } ]
}

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

model.addAttribute("response", (indented));

А затем показывает это на странице результатов jform, как показано ниже:

    <fieldset>
        <legend>Response:</legend>
            <strong>${response}</strong><br />

    </fieldset>

Я получаю что-то вроде этого:

{ "attributes" : [ { "nm" : "ACCOUNT", "error" : "null    
SYS00019CancellationException in CoreImpl fetchAttributes\n 
java.util.concurrent.CancellationException\n\tat 
java.util.concurrent.FutureTask$Sync.innerGet(FutureTask.java:231)\n\tat 
java.util.concurrent.FutureTask.", "status" : "ERROR" } ] }

который мне не нужен. Мне нужно было, как это было напечатано выше. Может кто-нибудь сказать мне, почему это произошло таким образом?

4b9b3361

Ответ 1

Чтобы отложить любой старый JSON, просто привяжите его как Object, например:

Object json = mapper.readValue(input, Object.class);

а затем записать его с отступом:

String indented = mapper.writerWithDefaultPrettyPrinter().writeValueAsString(json);

это позволяет избежать необходимости определять фактическое POJO для сопоставления данных.

Или вы можете использовать JsonNode (JSON Tree).

Ответ 2

Простейшее, а также наиболее компактное решение (для v.2.3.3):

ObjectMapper mapper = new ObjectMapper();
mapper.enable(SerializationFeature.INDENT_OUTPUT);

Ответ 3

Новый способ использования Jackson 1.9+ следующий:

Object json = OBJECT_MAPPER.readValue(diffResponseJson, Object.class);
String indented = OBJECT_MAPPER.writerWithDefaultPrettyPrinter()
                               .writeValueAsString(json);

Выход будет правильно отформатирован!

Ответ 4

Для Jackson 1.9 мы можем использовать следующий код для красивой печати. ​​

ObjectMapper objectMapper = new ObjectMapper();
objectMapper.enable(SerializationConfig.Feature.INDENT_OUTPUT);

Ответ 5

Я думаю, это самый простой способ украсить json-данные,

String indented = (new JSONObject(Response)).toString(4);

где Response - строка.

Просто передайте 4 (indentSpaces) в методе toString().

Примечание. Он отлично работает в андроиде без какой-либо библиотеки. Но в java вам нужно использовать библиотеку org.json.

Ответ 6

Похоже, это может быть ответ на ваш вопрос. Он говорит, что использует Spring, но я думаю, что это все равно поможет вам в вашем случае. Позвольте мне вставить код здесь, чтобы он стал более удобным:

import java.io.FileReader;

import org.codehaus.jackson.map.ObjectMapper;
import org.codehaus.jackson.map.ObjectWriter;

public class Foo
{
  public static void main(String[] args) throws Exception
  {
    ObjectMapper mapper = new ObjectMapper();
    MyClass myObject = mapper.readValue(new FileReader("input.json"), MyClass.class);
    // this is Jackson 1.x API only: 
    ObjectWriter writer = mapper.defaultPrettyPrintingWriter();
    // ***IMPORTANT!!!*** for Jackson 2.x use the line below instead of the one above: 
    // ObjectWriter writer = mapper.writer().withDefaultPrettyPrinter();
    System.out.println(writer.writeValueAsString(myObject));
  }
}

class MyClass
{
  String one;
  String[] two;
  MyOtherClass three;

  public String getOne() {return one;}
  void setOne(String one) {this.one = one;}
  public String[] getTwo() {return two;}
  void setTwo(String[] two) {this.two = two;}
  public MyOtherClass getThree() {return three;}
  void setThree(MyOtherClass three) {this.three = three;}
}

class MyOtherClass
{
  String four;
  String[] five;

  public String getFour() {return four;}
  void setFour(String four) {this.four = four;}
  public String[] getFive() {return five;}
  void setFive(String[] five) {this.five = five;}
}

Ответ 7

Вы можете достичь этого, используя следующие способы:

1. Использование Джексона из Apache

    String formattedData=new ObjectMapper().writerWithDefaultPrettyPrinter()
.writeValueAsString(YOUR_JSON_OBJECT);

Импорт нижеуказанного класса:

import com.fasterxml.jackson.databind.ObjectMapper;

Это зависимость от gradle:

compile 'com.fasterxml.jackson.core:jackson-core:2.7.3'
compile 'com.fasterxml.jackson.core:jackson-annotations:2.7.3'
compile 'com.fasterxml.jackson.core:jackson-databind:2.7.3'

2. Использование Gson от Google

String formattedData=new GsonBuilder().setPrettyPrinting()
    .create().toJson(YOUR_OBJECT);

Импорт нижеуказанного класса:

import com.google.gson.Gson;

Это gradle это:

compile 'com.google.code.gson:gson:2.8.2'

Здесь вы можете скачать правильную обновленную версию из репозитория.