需要下載第三方的jar :net.sf.json
import java.io.BufferedReader; import java.io.InputStream; import java.io.InputStreamReader; import java.net.URL; import java.util.ArrayList; import java.util.Iterator; import java.util.List; import java.util.Map; import java.util.Set; import org.apache.commons.collections.map.ListOrderedMap; import net.sf.json.JSONArray; import net.sf.json.JSONObject; /** * * 處理json的工具類. * <br>本類為處理json的工具類 * @author slj */ public class JsonTools { /** * * json轉換list. * <br>詳細說明 * @param jsonStr json字符串 * @return * @return List<Map<String,Object>> list * @throws * @author slj * @date 2013年12月24日 下午1:08:03 */ public static List<Map<String, Object>> parseJSON2List(String jsonStr){ JSONArray jsonArr = JSONArray.fromObject(jsonStr); List<Map<String, Object>> list = new ArrayList<Map<String,Object>>(); Iterator<JSONObject> it = jsonArr.iterator(); while(it.hasNext()){ JSONObject json2 = it.next(); list.add(parseJSON2Map(json2.toString())); } return list; } /** * * json轉換map. * <br>詳細說明 * @param jsonStr json字符串 * @return * @return Map<String,Object> 集合 * @throws * @author slj */ public static Map<String, Object> parseJSON2Map(String jsonStr){ ListOrderedMap map = new ListOrderedMap(); //最外層解析 JSONObject json = JSONObject.fromObject(jsonStr); for(Object k : json.keySet()){ Object v = json.get(k); //如果內層還是數組的話,繼續解析 if(v instanceof JSONArray){ List<Map<String, Object>> list = new ArrayList<Map<String,Object>>(); Iterator<JSONObject> it = ((JSONArray)v).iterator(); while(it.hasNext()){ JSONObject json2 = it.next(); list.add(parseJSON2Map(json2.toString())); } map.put(k.toString(), list); } else { map.put(k.toString(), v); } } return map; } /** * * 通過HTTP獲取JSON數據. * <br>通過HTTP獲取JSON數據返回list * @param url 鏈接 * @return * @return List<Map<String,Object>> list * @throws * @author slj */ public static List<Map<String, Object>> getListByUrl(String url){ try { //通過HTTP獲取JSON數據 InputStream in = new URL(url).openStream(); BufferedReader reader = new BufferedReader(new InputStreamReader(in)); StringBuilder sb = new StringBuilder(); String line; while((line=reader.readLine())!=null){ sb.append(line); } return parseJSON2List(sb.toString()); } catch (Exception e) { e.printStackTrace(); } return null; } /** * * 通過HTTP獲取JSON數據. * <br>通過HTTP獲取JSON數據返回map * @param url 鏈接 * @return * @return Map<String,Object> 集合 * @throws * @author slj */ public static Map<String, Object> getMapByUrl(String url){ try { //通過HTTP獲取JSON數據 InputStream in = new URL(url).openStream(); BufferedReader reader = new BufferedReader(new InputStreamReader(in)); StringBuilder sb = new StringBuilder(); String line; while((line=reader.readLine())!=null){ sb.append(line); } return parseJSON2Map(sb.toString()); } catch (Exception e) { e.printStackTrace(); } return null; } /** * * map轉換json. * <br>詳細說明 * @param map 集合 * @return * @return String json字符串 * @throws * @author slj */ public static String mapToJson(Map<String, String> map) { Set<String> keys = map.keySet(); String key = ""; String value = ""; StringBuffer jsonBuffer = new StringBuffer(); jsonBuffer.append("{"); for (Iterator<String> it = keys.iterator(); it.hasNext();) { key = (String) it.next(); value = map.get(key); jsonBuffer.append(key + ":" +"\""+ value+"\""); if (it.hasNext()) { jsonBuffer.append(","); } } jsonBuffer.append("}"); return jsonBuffer.toString(); } //test public static void main(String[] args) { String url = "http://..."; List<Map<String,Object>> list = getListByUrl(url); System.out.println(list); } }
比如解析:
{"data":[{"id":"402880566092af74016092ba010f0026_151429025888228961","WI_ACTIVITY_ID_":"manuscripts","WI_ID_":"151429025888228961","workflowName":"志書編纂1","tableId":"8a7a543d5ccf1bb3015ccf412169006d","workflowId":"8a7aef3d5cd871bf015cd876c65b0000","workflowCode":"ZSBZ_NEW","PROCESS_INSTANCE_ID_":"151429025753518344","WI_STATUS_KEY_":"12","explain":"超級管理員申請的2017-12-26 20:09:12志書編纂1"},{"id":"83838a7a5fec0991015fec0b11d70010_151149367104810227","WI_ACTIVITY_ID_":"taskAssigned","WI_ID_":"151149367104810227","workflowName":"專題編研","tableId":"8a8aacd9564a3a1901564a882a6c0022","workflowId":"297ee40a56ca38590156caa6a0bb0008","workflowCode":"ZTBY_ZT","PROCESS_INSTANCE_ID_":"151149367010400495","WI_STATUS_KEY_":"12","explain":"超級管理員申請的2017-11-24 11:21:09專題編研"},{"id":"948181865e08e7b0015e091ea117011b_150339155625410132","WI_ACTIVITY_ID_":"activity2","WI_ID_":"150339155625410132","workflowName":"退回整理庫","tableId":"402809815894218c01589560c7f90006","workflowId":"8383849458b8d25a0158b8dc9daa0000","workflowCode":"RETURNARRANGE","PROCESS_INSTANCE_ID_":"150339155603600640","WI_STATUS_KEY_":"12","explain":"超級管理員申請的2017-08-22 16:45:55退回整理庫"}],"pageNumber":1,"pageSize":3,"total":3,"totalPages":1}
獲取其中的data部分轉換為List<Map<String,Object>>
public List<Map<String,Object>> parseStringToListMap(String res) throws Exception{ List<Map<String,Object>> list=new ArrayList<Map<String,Object>>(); JSONObject jsonResult = new JSONObject(res); Iterator<String> nameItr = jsonResult.keys(); while (nameItr.hasNext()) { String name = nameItr.next(); if(name.equals("data")){ String data=jsonResult.getString(name); JSONArray jsonArr = JSONArray.fromObject(data); for(int s=0;s<jsonArr.size();s++){//便利取到每個map Map<String,Object> map = new HashMap<String,Object>(); String vas= jsonArr.get(s)==null?"":jsonArr.get(s).toString(); JSONObject jr=new JSONObject(vas); Iterator<String> nir = jr.keys(); while (nir.hasNext()) {//取到map里的每個值 String json2 = nir.next(); String value= jr.getString(json2); map.put(json2, value); } list.add(map); } } } return list; }
