これは私が持っている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
を(Jacksonを使用して)Pretty Print 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
}
]
}
上記の私の例に基づいて、誰かが私に例を提供できますか?このシナリオを達成する方法例がたくさんあることは知っていますが、それらを正しく理解することはできません。簡単な例でどんな助けでも理解されるでしょう。
更新日
以下は私が使っているコードです。
ObjectMapper mapper = new ObjectMapper();
System.out.println(mapper.defaultPrettyPrintingWriter().writeValueAsString(jsonString));
しかし、これは私が上記のように出力を必要とした方法ではうまくいきません。
上記のJSONに使用しているPOJOは次のとおりです。
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;
}
JSONに適したPOJOを取得したかどうかを教えてもらえますか。
更新日
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));
そして、以下のように結果フォームのJSPページにそれを示しています:
<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" } ] }
私は必要ありません。私はそれが上にプリントアウトされた方法が必要でした。なぜそれがこのようにして起こったのか誰かに教えてもらえますか?
古いJSONをインデントするには、単に次のようにObject
としてバインドします。
Object json = mapper.readValue(input, Object.class);
それから字下げして書き出します。
String indented = mapper.writerWithDefaultPrettyPrinter().writeValueAsString(json);
これにより、データをマップする実際のPOJOを定義する必要がなくなります。
あるいはJsonNode
(JSON Tree)を使用することもできます。
(v2.3.3用)最もシンプルでまた最もコンパクトなソリューション
ObjectMapper mapper = new ObjectMapper();
mapper.enable(SerializationFeature.INDENT_OUTPUT);
Jackson 1.9+を使用した新しい方法は次のとおりです。
Object json = OBJECT_MAPPER.readValue(diffResponseJson, Object.class);
String indented = OBJECT_MAPPER.writerWithDefaultPrettyPrinter()
.writeValueAsString(json);
出力は正しくフォーマットされます。
Jackson 1.9の場合、きれいに印刷するために次のコードを使用できます。
ObjectMapper objectMapper = new ObjectMapper();
objectMapper.enable(SerializationConfig.Feature.INDENT_OUTPUT);
私は、これがJSONデータを美しくするための最も簡単なテクニックだと思います、
String indented = (new JSONObject(Response)).toString(4);
ここで、Responseは文字列です。
toString()
メソッドに4(indentSpaces)を渡すだけです。
注:これは、ライブラリがなくてもAndroidで正常に動作します。しかしJavaでは org.json ライブラリを使わなければなりません。
これはあなたの質問に対する答えかもしれません 。それはそれが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;}
}
以下の方法でこれを達成できます。
1.ジャクソンを使う
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。Google Gsonを使用
String formattedData=new GsonBuilder().setPrettyPrinting()
.create().toJson(YOUR_OBJECT);
以下のクラスをインポートします。
import com.google.gson.Gson;
それはgradleです:
compile 'com.google.code.gson:gson:2.8.2'
ここから、あなたはリポジトリから正しい更新版をダウンロードすることができます。
これがお役に立てば幸いです。
ありがとう:)