引入jar包:json-20140107.jar, 链接地址:http://pan.baidu.com/s/1pJoI3Jd
关键类:JSONHelper
package com.sitech.echn.utils; import java.util.ArrayList; import java.util.HashMap; import java.util.Iterator; import java.util.List; import java.util.Map; import org.json.JSONArray; import org.json.JSONException; import org.json.JSONObject; public class JSONHelper { /* * 将json字符串转换为List集合 */ @SuppressWarnings("unchecked") public static List<Map<String, Object>> jsonObjList(String jsonArrStr) { List<Map<String, Object>> jsonList = new ArrayList<Map<String, Object>>(); JSONArray jsonArr = null; try { jsonArr = new JSONArray(jsonArrStr); jsonList = (List<Map<String, Object>>)JSONHelper.jsonToList(jsonArr); } catch (JSONException e) { System.out.println("Json字符串转换异常!"); e.printStackTrace(); } return jsonList; } /** * 将json对象的键值存放在集合,映射table的column * * @param map * @return */ public static List<String> jsonMapKeysList(Map<?, ?> map) { List<String> jsonjsonList = new ArrayList<String>(); String columnStr = "column"; for (int i = 0; i < map.keySet().size(); i++) { jsonjsonList.add(columnStr + (i + 1)); } System.out.println(jsonjsonList.size()); return jsonjsonList; } /** * 将传递近来的json数组转换为List集合 * * @param jsonArr * @return * @throws JSONException */ public static List<?> jsonToList(JSONArray jsonArr) throws JSONException { List<Object> jsonToMapList = new ArrayList<Object>(); for (int i = 0; i < jsonArr.length(); i++) { Object object = jsonArr.get(i); if (object instanceof JSONArray) { jsonToMapList.add(JSONHelper.jsonToList((JSONArray) object)); } else if (object instanceof JSONObject) { jsonToMapList.add(JSONHelper.jsonToMap((JSONObject) object)); } else { jsonToMapList.add(object); } } return jsonToMapList; } /** * 将传递近来的json对象转换为Map集合 * * @param jsonObj * @return * @throws JSONException */ @SuppressWarnings("unchecked") public static Map<String, Object> jsonToMap(JSONObject jsonObj) throws JSONException { Map<String, Object> jsonMap = new HashMap<String, Object>(); Iterator<String> jsonKeys = jsonObj.keys(); while (jsonKeys.hasNext()) { String jsonKey = jsonKeys.next(); Object jsonValObj = jsonObj.get(jsonKey); if (jsonValObj instanceof JSONArray) { jsonMap.put(jsonKey, JSONHelper.jsonToList((JSONArray) jsonValObj)); } else if (jsonValObj instanceof JSONObject) { jsonMap.put(jsonKey, JSONHelper.jsonToMap((JSONObject) jsonValObj)); } else { jsonMap.put(jsonKey, jsonValObj); } } return jsonMap; } }
4. 测试代码:
import java.util.List;
import java.util.Map;
import com.cmcc.zysoft.easyswap.util.JSONHelper;
public class Test {
@org.junit.Test
public void testToList() {
List<Map<String, Object>> list = JSONHelper.jsonObjList(
"[{\"operateType\":\"A\",\"prodPrcId\":\"PIBPG410\",\"prodId\":\"BPG410\"},"
+ "{\"operateType\":\"A\",\"prodPrcId\":\"PIBPG400\",\"prodId\":\"BPG400\"},"
+ "{\"operateType\":\"A\",\"prodPrcId\":\"PIBPG420\",\"prodId\":\"BPG420\"},"
+ "{\"operateType\":\"A\",\"prodPrcId\":\"PIBPG410\",\"prodId\":\"BPG410\"},"
+ "{\"operateType\":\"A\",\"prodPrcId\":\"PIBPG400\",\"prodId\":\"BPG400\"},"
+ "{\"operateType\":\"A\",\"prodPrcId\":\"PIBPG420\",\"prodId\":\"BPG420\"}]");
System.out.println(list.size());
System.out.println(list.get(2).get("prodPrcId"));
}
}
@org.junit.Test
public void testToMap() {
Map<String, Object> map = JSONHelper.jsonToMap(new JSONObject("{\"operateType\":\"A\",\"prodPrcId\":\"PIBPG410\",\"prodId\":\"BPG410\"}"));
System.out.println(map.get("operateType"));
System.out.println(map.get("prodPrcId"));
}