有没有标准方法可以这样做?
答案 0 :(得分:3)
简而言之:不,因为JSON没有原始的有序地图类型。
第一步是确定客户端的要求,只要解码JSON字符串即可。由于JSON规范没有有序的地图类型,因此您必须决定要使用的表示。您的选择取决于客户端的解码要求。
如果您可以完全控制JSON字符串的解码,则可以使用JSON库按顺序将对象按顺序编码到映射中,该JSON库保证按照传入的迭代器的顺序对事物进行序列化。 / p>
如果你不能保证这一点,你应该自己想出一个代表。两个简单的例子是:
交替清单:
"[key1, value1, key2, value2]"
键/值输入对象列表:
"[{key: key1, val:value1}, {key: key2, val:value2}]"
一旦你想出了这种表示,就可以很容易地编写一个循环在SimpleOrderedMap上的简单函数。例如:
JSONArray jarray = new JSONArray(); for(Map.Entry e : simpleOrderedMap) { jarray.put(e.key()); jarray.put(e.value()); }
答案 1 :(得分:2)
Java版:
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Map;
import java.util.Map.Entry;
import org.apache.solr.common.util.NamedList;
public class SolrMapConverter {
@SuppressWarnings({ "unchecked", "rawtypes" })
public static Object toMap(Object entry) {
Object response = null;
if (entry instanceof NamedList) {
response = new HashMap<>();
NamedList lst = (NamedList) entry;
for (int i = 0; i < lst.size(); i++) {
((Map) response).put(lst.getName(i), toMap(lst.getVal(i)));
}
} else if (entry instanceof Iterable) {
response = new ArrayList<>();
for (Object e : (Iterable) entry) {
((ArrayList<Object>) response).add(toMap(e));
}
} else if (entry instanceof Map) {
response = new HashMap<>();
for (Entry<String, ?> e : ((Map<String, ?>) entry).entrySet()) {
((Map) response).put(e.getKey(), toMap(e.getValue()));
}
} else {
return entry;
}
return response;
}
}
答案 2 :(得分:0)
简单地添加要映射的字段将不起作用,因为复杂的对象(不会序列化为JSON)可能就在那里。
这是一个很常见的代码。
protected static toMap(entry){
def response
if(entry instanceof SolrDocumentList){
def docs = []
response = [numFound:entry.numFound, maxScore:entry.maxScore, start:entry.start, docs:docs]
entry.each {
docs << toMap(it)
}
} else
if(entry instanceof List){
response = []
entry.each {
response << toMap(it)
}
} else
if(entry instanceof Iterable){
response = [:]
entry.each {
if(it instanceof Map.Entry)
response.put(it.key, toMap(it.value))
else
response.put(entry.hashCode(), toMap(it))
}
} else
if (entry instanceof Map){
response = [:]
entry.each {
if(it instanceof Map.Entry)
response.put(it.key, toMap(it.value))
else
response.put(entry.hashCode(), toMap(it))
}
} else {
response = entry
}
return response
}