जवाबों:
आप उपयोग कर सकते हैं:
new JSONObject(map);
सावधानी: यह केवल एक के लिए काम करेगाMap<String, String>!
अन्य कार्य आप इसके प्रलेखन http://stleary.github.io/JSON-java/index.html से प्राप्त कर सकते हैं
Map
में JSONObject
लेकिन तुम कैसे JSONObject से इस नक्शे मिल सकता है?
मनमाने ढंग से जटिल वस्तुओं को क्रमबद्ध करने के लिए भी गन्स का उपयोग किया जा सकता है।
यहाँ आप इसका उपयोग कैसे करें:
Gson gson = new Gson();
String json = gson.toJson(myObject);
Gson
स्वचालित रूप से संग्रह को JSON
सरणियों में बदल देगा । गन्स निजी क्षेत्रों को क्रमबद्ध कर सकते हैं और स्वचालित रूप से क्षणिक क्षेत्रों की उपेक्षा कर सकते हैं।
उदाहरण json का उपयोग कर
Map<String, Object> data = new HashMap<String, Object>();
data.put( "name", "Mars" );
data.put( "age", 32 );
data.put( "city", "NY" );
JSONObject json = new JSONObject();
json.putAll( data );
System.out.printf( "JSON: %s", json.toString(2) );
उत्पादन ::
JSON: {
"age": 32,
"name": "Mars",
"city": "NY"
}
आप Google के GSON का उपयोग करने का भी प्रयास कर सकते हैं ।Google का GSON जावा ऑब्जेक्ट को उनके JSON प्रतिनिधित्व में परिवर्तित करने के लिए सर्वोत्तम लाइब्रेरी उपलब्ध है।
2
में क्या करता है json.toString(
)
आप परिवर्तित कर सकते हैं Map
करने के लिए JSON
उपयोग करते हुए Jackson
इस प्रकार है:
Map<String,Object> map = new HashMap<>();
//You can convert any Object.
String[] value1 = new String[] { "value11", "value12", "value13" };
String[] value2 = new String[] { "value21", "value22", "value23" };
map.put("key1", value1);
map.put("key2", value2);
map.put("key3","string1");
map.put("key4","string2");
String json = new ObjectMapper().writeValueAsString(map);
System.out.println(json);
के लिए मावेन निर्भरताएँ Jackson
:
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-core</artifactId>
<version>2.5.3</version>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId>
<version>2.5.3</version>
<scope>compile</scope>
</dependency>
यदि आप JSONObject
पुस्तकालय का उपयोग कर रहे हैं , तो आप मानचित्र को JSON
निम्नानुसार परिवर्तित कर सकते हैं:
Map<String, Object> map = new HashMap<>();
// Convert a map having list of values.
String[] value1 = new String[] { "value11", "value12", "value13" };
String[] value2 = new String[] { "value21", "value22", "value23" };
map.put("key1", value1);
map.put("key2", value2);
JSONObject json = new JSONObject(map);
System.out.println(json);
के लिए मावेन निर्भरताएँ JSONObject
:
<dependency>
<groupId>org.json</groupId>
<artifactId>json</artifactId>
<version>20140107</version>
</dependency>
आशा है कि यह मदद करेगा। खुश कोडिंग।
मेरे मामले में मुझे कोई निर्भरता नहीं चाहिए थी। Java 8 का उपयोग करके आप JSON को इस सरल स्ट्रिंग के रूप में प्राप्त कर सकते हैं:
Map<String, Object> map = new HashMap<>();
map.put("key", "value");
map.put("key2", "value2");
String json = "{"+map.entrySet().stream()
.map(e -> "\""+ e.getKey() + "\"" + ":\"" + String.valueOf(e.getValue()) + "\"")
.collect(Collectors.joining(", "))+"}";
"
, तो यह टूट जाता है
आप बस नक्शे में गणना कर सकते हैं और JSONObject में मुख्य-मूल्य जोड़े जोड़ सकते हैं
तरीका :
private JSONObject getJsonFromMap(Map<String, Object> map) throws JSONException {
JSONObject jsonData = new JSONObject();
for (String key : map.keySet()) {
Object value = map.get(key);
if (value instanceof Map<?, ?>) {
value = getJsonFromMap((Map<String, Object>) value);
}
jsonData.put(key, value);
}
return jsonData;
}
अंडरस्कोर-जावा लाइब्रेरी हैश मैप या एरे लिस्ट को जसन और वाइस वर्जन में बदल सकती है।
import com.github.underscore.lodash.U;
import java.util.*;
public class Main {
public static void main(String[] args) {
Map<String, Object> map = new LinkedHashMap<>();
map.put("1", "a");
map.put("2", "b");
System.out.println(U.toJson(map));
// {
// "1": "a",
// "2": "b"
// }
}
}
पार्टी में देर हो रही है लेकिन यहाँ मेरा GSON है को क्रमबद्ध करने के लिए एडहॉक लेखक है। मुझे json स्ट्रिंग विशेषताओं के रूप में मुख्य-मूल्य वाले जोड़े के मानचित्र लिखना था, एक पूर्णांक प्रकार के होने की उम्मीद थी। मैं इस सरल usecase के लिए कस्टम जावाबीन आवरण बनाना नहीं चाहता था।
GSON JsonWriter वर्ग कुछ दृढ़ता से टाइप किए गए लेखक.वल्यू () फ़ंक्शंस वाले सीरलाइज़र वर्ग का उपयोग करना आसान है।
// write Map as JSON document to http servlet response
Map<String,String> sd = DAO.getSD(123);
res.setContentType("application/json; charset=UTF-8");
res.setCharacterEncoding("UTF-8");
JsonWriter writer = new JsonWriter(new OutputStreamWriter(res.getOutputStream(), "UTF-8"));
writer.beginObject();
for(String key : sd.keySet()) {
String val = sd.get(key);
writer.name(key);
if (key.equals("UniqueID") && val!=null)
writer.value(Long.parseLong(val));
else
writer.value(val);
}
writer.endObject();
writer.close();
यदि कोई भी कस्टम प्रकार की आवश्यकता नहीं है, तो मैं सिर्फ toson () फ़ंक्शन का उपयोग कर सकता हूं। gson-2.2.4.jar पुस्तकालय बिना किसी क्रूर निर्भरता के 190KB के अंतर्गत है। बड़े फ्रेमवर्क एकीकरण के बिना किसी भी कस्टम सर्वलेट ऐप या स्टैंडअलोन एप्लिकेशन पर उपयोग करना आसान है।
Gson gson = new Gson();
String json = gson.toJson(myMap);
यदि आपको कोड में इसका उपयोग करने की आवश्यकता है।
Gson gsone = new Gson();
JsonObject res = gsone.toJsonTree(sqlParams).getAsJsonObject();
बेहतर है कि कभी देर न करें। यदि आप सिलसिलेवार सूची रखना चाहते हैं तो मैंने जीएएसएन का उपयोग हैशपॉप की सूची को स्ट्रिंग में बदलने के लिए किया।
List<HashMap<String, String>> list = new ArrayList<>();
HashMap<String,String> hashMap = new HashMap<>();
hashMap.add("key", "value");
hashMap.add("key", "value");
hashMap.add("key", "value");
list.add(hashMap);
String json = new Gson().toJson(list);
यह json
पैदा करता है[{"key":"value","key":"value","key":"value"}]
Gson
।
यह समाधान जटिल JSONs के साथ काम करता है:
public Object toJSON(Object object) throws JSONException {
if (object instanceof HashMap) {
JSONObject json = new JSONObject();
HashMap map = (HashMap) object;
for (Object key : map.keySet()) {
json.put(key.toString(), toJSON(map.get(key)));
}
return json;
} else if (object instanceof Iterable) {
JSONArray json = new JSONArray();
for (Object value : ((Iterable) object)) {
json.put(toJSON(value));
}
return json;
}
else {
return object;
}
}
हम Gson का उपयोग करते हैं।
Gson gson = new Gson();
Type gsonType = new TypeToken<HashMap>(){}.getType();
String gsonString = gson.toJson(elements,gsonType);
आप XStream का उपयोग कर सकते हैं - यह वास्तव में आसान है। यहां उदाहरण देखें
package com.thoughtworks.xstream.json.test;
import com.thoughtworks.xstream.XStream;
import com.thoughtworks.xstream.io.json.JettisonMappedXmlDriver;
public class WriteTest {
public static void main(String[] args) {
HashMap<String,String> map = new HashMap<String,String>();
map.add("1", "a");
map.add("2", "b");
XStream xstream = new XStream(new JettisonMappedXmlDriver());
System.out.println(xstream.toXML(map));
}
}
यदि आप उपयोग कर रहे हैं net.sf.json.JSONObject
तो आपको JSONObject(map)
इसमें कंस्ट्रक्टर नहीं मिलेगा । आपको public static JSONObject fromObject( Object object )
विधि का उपयोग करना होगा । यह विधि JSON के स्वरूपित स्ट्रिंग्स, मैप्स, डायनाबीन्स और JavaBeans को स्वीकार करती है।
JSONObject jsonObject = JSONObject.fromObject(myMap);
यदि आप जटिल वस्तुओं का उपयोग करते हैं, तो आपको https://ComxxflowKeySerialization () , जैसा कि https://stackoverflow.com/a/24635655/2914140 और https://stackoverflow.com/a/26374648/2914140 में बताया गया है, लागू करना चाहिए ।
Gson gson = new GsonBuilder().enableComplexMapKeySerialization().create();
Map<Point, String> original = new LinkedHashMap<Point, String>();
original.put(new Point(5, 6), "a");
original.put(new Point(8, 8), "b");
System.out.println(gson.toJson(original));
आउटपुट होगा:
{
"(5,6)": "a",
"(8,8)": "b"
}
GSON या JSON पार्सिंग लाइब्रेरी की कोई आवश्यकता नहीं है।
बस का उपयोग कर new JSONObject(Map<String, JSONObject>).toString()
, जैसे:
/**
* convert target map to JSON string
*
* @param map the target map
* @return JSON string of the map
*/
@NonNull public String toJson(@NonNull Map<String, Target> map) {
final Map<String, JSONObject> flatMap = new HashMap<>();
for (String key : map.keySet()) {
try {
flatMap.put(key, toJsonObject(map.get(key)));
} catch (JSONException e) {
e.printStackTrace();
}
}
try {
// 2 indentSpaces for pretty printing
return new JSONObject(flatMap).toString(2);
} catch (JSONException e) {
e.printStackTrace();
return "{}";
}
}
import org.json.JSONObject;
HashMap<Object, Object> map = new HashMap<>();
String[] list={"Grader","Participant"};
String[] list1={"Assistant","intern"};
map.put("TeachingAssistant",list);
map.put("Writer",list1);
JSONObject jsonObject = new JSONObject(map);
System.out.printf(jsonObject.toString());
// Result: {"TeachingAssistant":["Grader","Participant"],"Writer":["Assistant","intern"]}
अगर आपको वास्तव में हाशपा की जरूरत नहीं है तो आप ऐसा कुछ कर सकते हैं:
String jsonString = new JSONObject() {{
put("firstName", user.firstName);
put("lastName", user.lastName);
}}.toString();
आउटपुट:
{
"firstName": "John",
"lastName": "Doe"
}
HashMap
, और यह उत्तर नहीं देता है।
मैं अलीबाबा तेज, आसान और सरल का उपयोग कर रहा हूँ:
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>VERSION_CODE</version>
</dependency>
और आयात:
import com.alibaba.fastjson.JSON;
फिर:
String text = JSON.toJSONString(obj); // serialize
VO vo = JSON.parseObject("{...}", VO.class); //unserialize
सब कुछ ठीक है।
आप Gson का उपयोग कर सकते हैं । यह लाइब्रेरी जावा ऑब्जेक्ट्स को JSON ऑब्जेक्ट्स में बदलने के लिए सरल तरीके प्रदान करती है और इसके विपरीत।
उदाहरण:
GsonBuilder gb = new GsonBuilder();
Gson gson = gb.serializeNulls().create();
gson.toJson(object);
जब आप डिफ़ॉल्ट के अलावा कॉन्फ़िगरेशन विकल्प सेट करने की आवश्यकता होती है तो आप GsonBuilder का उपयोग कर सकते हैं। उपरोक्त उदाहरण में, रूपांतरण प्रक्रिया ऑब्जेक्ट से अशक्त विशेषताओं को अनुक्रमित भी करेगी।
हालांकि, यह दृष्टिकोण केवल गैर-सामान्य प्रकारों के लिए काम करता है। जेनेरिक प्रकारों के लिए आपको toson (ऑब्जेक्ट, टाइप) का उपयोग करने की आवश्यकता होती है।
Gson के बारे में अधिक जानकारी यहाँ ।
याद रखें कि ऑब्जेक्ट को Serializable इंटरफ़ेस को लागू करना होगा ।
यह मेरे लिए काम करता है:
import groovy.json.JsonBuilder
properties = new Properties()
properties.put("name", "zhangsan")
println new JsonBuilder(properties).toPrettyString()
थोड़ा और अधिक जटिल मानचित्रों के लिए रास्ता टाइप करें और TypeToken.getParameterized का उपयोग करके सूचीबद्ध करें करें।
हमारे पास एक नक्शा है जो इस तरह दिखता है:
Map<Long, List<NewFile>> map;
हम इस तरह के उपरोक्त getParameterized विधि का उपयोग कर प्रकार प्राप्त करते हैं :
Type listOfNewFiles = TypeToken.getParameterized(ArrayList.class, NewFile.class).getType();
Type mapOfList = TypeToken.getParameterized(LinkedHashMap.class, Long.class, listOfNewFiles).getType();
और फिर Gson वस्तु का उपयोग fromJson का उपयोग कर इस तरह विधि mapOfList इस तरह वस्तु:
Map<Long, List<NewFile>> map = new Gson().fromJson(fileContent, mapOfList);
उल्लिखित वस्तु न्यूफ़ाइल इस प्रकार है:
class NewFile
{
private long id;
private String fileName;
public void setId(final long id)
{
this.id = id;
}
public void setFileName(final String fileName)
{
this.fileName = fileName;
}
}
Deserialized JSON इस तरह दिखता है:
{
"1": [
{
"id": 12232,
"fileName": "test.html"
},
{
"id": 12233,
"fileName": "file.txt"
},
{
"id": 12234,
"fileName": "obj.json"
}
],
"2": [
{
"id": 122321,
"fileName": "test2.html"
},
{
"id": 122332,
"fileName": "file2.txt"
},
{
"id": 122343,
"fileName": "obj2.json"
}
]
}
सेलेनियम में कस्टम कमांड्स से रिस्पॉन्स को डिसेररलाइज़ करते समय मुझे इसी तरह की समस्या का सामना करना पड़ा। प्रतिक्रिया जौनसारी थी, लेकिन सेलेनियम आंतरिक रूप से एक java.util में अनुवाद करता है। हाशपा [स्ट्रिंग, ऑब्जेक्ट]
यदि आप scala से परिचित हैं और JSON के लिए play-API का उपयोग करते हैं, तो आपको इससे लाभ हो सकता है:
import play.api.libs.json.{JsValue, Json}
import scala.collection.JavaConversions.mapAsScalaMap
object JsonParser {
def parse(map: Map[String, Any]): JsValue = {
val values = for((key, value) <- map) yield {
value match {
case m: java.util.Map[String, _] @unchecked => Json.obj(key -> parse(m.toMap))
case m: Map[String, _] @unchecked => Json.obj(key -> parse(m))
case int: Int => Json.obj(key -> int)
case str: String => Json.obj(key -> str)
case bool: Boolean => Json.obj(key -> bool)
}
}
values.foldLeft(Json.obj())((temp, obj) => {
temp.deepMerge(obj)
})
}
}
छोटे कोड का विवरण:
जब तक बुनियादी प्रकार (स्ट्रिंग, इंटेगर, बुलियन) पाए जाते हैं तब तक कोड हैशमैप के माध्यम से पुन: प्राप्त होता है। इन बुनियादी प्रकारों को सीधे JsObject में लपेटा जा सकता है। जब पुनरावृत्ति सामने आती है, तो गहरी निर्मित वस्तुओं को समाप्त कर देता है।
'@unchecked' टाइप इरेज़र चेतावनियों का ध्यान रखता है।
सबसे पहले अपनी सभी वस्तुओं को वैध स्ट्रिंग्स में परिवर्तित करें
HashMap<String, String> params = new HashMap<>();
params.put("arg1", "<b>some text</b>");
params.put("arg2", someObject.toString());
फिर एक org.json.JSONObject में पूरा नक्शा डालें
JSONObject postData = new JSONObject(params);
अब आप केवल ऑब्जेक्ट के इनस्ट्रिंग को कॉल करके JSON प्राप्त कर सकते हैं
postData.toString()
//{"arg1":"<b>some text<\/b>" "arg2":"object output"}
एक नया JSONObject बनाएँ
JSONObject o = new JSONObject(postData.toString());
या HTTP पर भेजने के लिए बाइट सरणी के रूप में
postData.toString().getBytes("UTF-8");