Ответы:
Ты можешь использовать:
new JSONObject(map);
Внимание: это будет работать только дляMap<String, String>!
Другие функции вы можете получить из его документации
http://stleary.github.io/JSON-java/index.html
Map
в JSONObject
но как вы можете получить эту карту от JSONObject?
Gson также может быть использован для сериализации произвольно сложных объектов.
Вот как вы используете это:
Gson gson = new Gson();
String json = gson.toJson(myObject);
Gson
автоматически преобразует коллекции в JSON
массивы. Gson может сериализовать приватные поля и автоматически игнорировать переходные поля.
Пример использования 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"
}
Вы также можете попробовать использовать GSON от Google. GSON от Google - лучшая библиотека для преобразования объектов Java в их представление JSON.
2
делать в json.toString(
2`)
Вы можете преобразовать 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);
Maven Зависимости для 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);
Maven Зависимости для 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;
}
Библиотека Underscore-java может конвертировать хэш-карту или список массивов в json и наоборот.
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 для сериализации hashmap. Мне пришлось написать карту пар ключ-значение в виде строковых атрибутов json, ожидая, что один конкретный будет целочисленным типом. Я не хотел создавать пользовательскую оболочку JavaBean для этого простого варианта использования.
Класс GSON JsonWriter - это простой в использовании класс сериализатора, содержащий несколько строго типизированных функций writer.value ().
// 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();
Если не нужен ни один из пользовательских типов, я мог бы просто использовать функцию toJson (). Библиотека gson-2.2.4.jar имеет размер менее 190 КБ без каких-либо брутальных зависимостей. Легко использовать в любом пользовательском приложении сервлета или автономном приложении без больших интегрированных сред.
Gson gson = new Gson();
String json = gson.toJson(myMap);
Лучше опоздать, чем никогда. Я использовал GSON для преобразования списка HashMap в строку, если вы хотите иметь сериализованный список.
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
.
Это решение работает со сложными файлами JSON:
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, Maps, DynaBeans и JavaBeans.
JSONObject jsonObject = JSONObject.fromObject(myMap);
Если вы используете сложные объекты, вы должны применить enableComplexMapKeySerialization () , как указано в https://stackoverflow.com/a/24635655/2914140 и https://stackoverflow.com/a/26374888/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"]}
Если вам не нужен HashMap, вы можете сделать что-то вроде этого:
String jsonString = new JSONObject() {{
put("firstName", user.firstName);
put("lastName", user.lastName);
}}.toString();
Вывод:
{
"firstName": "John",
"lastName": "Doe"
}
HashMap
, и это не дает ответа.
Я использую Alibaba fastjson, легко и просто:
<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 . Эта библиотека предоставляет простые методы для преобразования объектов Java в объекты JSON и наоборот.
Пример:
GsonBuilder gb = new GsonBuilder();
Gson gson = gb.serializeNulls().create();
gson.toJson(object);
Вы можете использовать GsonBuilder, когда вам нужно установить параметры конфигурации, отличные от настроек по умолчанию. В приведенном выше примере процесс преобразования также сериализует нулевые атрибуты объекта.
Однако этот подход работает только для неуниверсальных типов. Для универсальных типов вам нужно использовать toJson (object, Type).
Больше информации о Gson здесь .
Помните, что объект должен реализовывать интерфейс Serializable .
это работает для меня:
import groovy.json.JsonBuilder
properties = new Properties()
properties.put("name", "zhangsan")
println new JsonBuilder(properties).toPrettyString()
Gson способ для немного более сложных карт и списков, используя метод 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 из метода Json, как этот, используя объект mapOfList, например:
Map<Long, List<NewFile>> map = new Gson().fromJson(fileContent, mapOfList);
Упомянутый объект NewFile выглядит так:
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;
}
}
Десериализованный 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"
}
]
}
Я столкнулся с подобной проблемой при десериализации ответа от пользовательских команд в селене. Ответ был json, но селен внутренне переводит это в java.util.HashMap [String, Object]
Если вы знакомы с scala и используете play-API для JSON, вы можете воспользоваться этим:
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)
})
}
}
Небольшое описание кода:
Код рекурсивно проходит через HashMap, пока не будут найдены базовые типы (String, Integer, Boolean). Эти основные типы могут быть непосредственно включены в JsObject. Когда рекурсия развернута, deepmerge объединяет созданные объекты.
@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, просто вызвав toString объекта
postData.toString()
//{"arg1":"<b>some text<\/b>" "arg2":"object output"}
Создать новый JSONObject
JSONObject o = new JSONObject(postData.toString());
Или как байтовый массив для отправки по HTTP
postData.toString().getBytes("UTF-8");