如何在 Java 中将 hashmap 转换或转换为 JSON 对象,并再次将 JSON 对象转换为 JSON 字符串?
29 回答
您可以使用:
new JSONObject(map);
注意:这仅适用于Map<String, String>!
您可以从其文档
http://stleary.github.io/JSON-java/index.html中获得其他功能
Gson也可以用来序列化任意复杂的对象。
以下是你如何使用它:
Gson gson = new Gson();
String json = gson.toJson(myObject);
Gson
将自动将集合转换为JSON
数组。Gson 可以序列化私有字段并自动忽略瞬态字段。
您可以转换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` 库,则可以将 map 转换为 `JSON`,如下所示:
JSON对象库:
import org.json.JSONObject;
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` 的 Maven 依赖项:
<dependency>
<groupId>org.json</groupId>
<artifactId>json</artifactId>
<version>20140107</version>
</dependency>
希望这会有所帮助。快乐编码。
使用 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 是可用于将 Java 对象转换为其 JSON 表示形式的最佳库。
就我而言,我不想要任何依赖。使用 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.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 字符串属性,期望一个特定的整数类型。我不想为这个简单的用例创建自定义 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 库不到 190KB,没有任何残酷的依赖。易于在任何自定义 servlet 应用程序或独立应用程序上使用,无需大型框架集成。
Gson gson = new Gson();
String json = gson.toJson(myMap);
这通常是 Json 库的工作,您不应该尝试自己做。所有 json 库都应实现您的要求,您可以在页面底部的json.org上找到 Java Json 库列表。
如果您需要在代码中使用它。
Gson gsone = new Gson();
JsonObject res = gsone.toJsonTree(sqlParams).getAsJsonObject();
迟到总比没有好。如果您想要一个序列化列表,我使用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"}]
此解决方案适用于复杂的 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;
}
}
我找到了另一种处理方式。
Map obj=new HashMap();
obj.put("name","sonoo");
obj.put("age",new Integer(27));
obj.put("salary",new Double(600000));
String jsonText = JSONValue.toJSONString(obj);
System.out.print(jsonText);
希望这可以帮助。
谢谢。
对于那些org.json.simple.JSONObject
使用JSONObject
.
JSONObject object = (JSONObject) new JSONParser().parse(JSONObject.toJSONString(map));
我们使用 Gson。
Gson gson = new Gson();
Type gsonType = new TypeToken<HashMap>(){}.getType();
String gsonString = gson.toJson(elements,gsonType);
这是我的 GSON 单线解决方案:
myObject = new Gson().fromJson(new Gson().toJson(myHashMap), MyClass.class);
If you don't really need HashMap then you can do something like that:
String jsonString = new JSONObject() {{
put("firstName", user.firstName);
put("lastName", user.lastName);
}}.toString();
Output:
{
"firstName": "John",
"lastName": "Doe"
}
我用的是阿里巴巴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
一切都好。
如果您使用 JSR 374: Java API for JSON Processing ( javax json ) 这似乎可以解决问题:
JsonObjectBuilder job = Json.createObjectBuilder((Map<String, Object>) obj);
JsonObject jsonObject = job.build();
您可以使用 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 格式的字符串、地图、DynaBeans 和 JavaBeans。
JSONObject jsonObject = JSONObject.fromObject(myMap);
使用TypeToken.getParameterized方法的更复杂的地图和列表的 Gson 方式:
我们有一个如下所示的地图:
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();
然后使用像这样使用mapOfList对象的 Gson 对象fromJson方法,如下所示:
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"
}
]
}
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"]}
不需要 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 "{}";
}
}
如果您使用复杂对象,则应应用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"
}
这对我有用:
import groovy.json.JsonBuilder
properties = new Properties()
properties.put("name", "zhangsan")
println new JsonBuilder(properties).toPrettyString()
您可以使用Gson。这个库提供了简单的方法来将 Java 对象转换为 JSON 对象,反之亦然。
例子:
GsonBuilder gb = new GsonBuilder();
Gson gson = gb.serializeNulls().create();
gson.toJson(object);
当您需要设置非默认配置选项时,您可以使用 GsonBuilder。在上面的示例中,转换过程还将从 object 中序列化 null 属性。
但是,这种方法仅适用于非泛型类型。对于泛型类型,您需要使用 toJson(object, Type)。
有关 Gson 的更多信息,请点击此处。
请记住,对象必须实现Serializable接口。
从 selenium 中的自定义命令反序列化响应时,我遇到了类似的问题。响应是 json,但 selenium 在内部将其转换为 java.util.HashMap[String, Object]
如果您熟悉 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)
})
}
}
小代码说明:
代码递归遍历 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);
现在您可以通过简单地调用对象的 toString 来获取 JSON
postData.toString()
//{"arg1":"<b>some text<\/b>" "arg2":"object output"}
创建一个新的 JSONObject
JSONObject o = new JSONObject(postData.toString());
或作为通过 HTTP 发送的字节数组
postData.toString().getBytes("UTF-8");