<p>花了我三个多小时(java还需要努力啊);</p>
<p>只有我自己看得懂,哈哈!!!!</p>
<p>/**elbert.chenh寫於2010年1月5日晚<br> * 实现如下功能<br> * 1.将用户传递的个性化的jsonstr队列转换为标准化的统一的jsonstr队列<br> * 如队列中的元素{/"taskId/":/"t01/",/"sceneId/":/"s01/",/"caseId/":/"cs01/",/"SYNOPSIS/":/"p1/",/"id/":1,/"cpu/":/"cpu01/"}<br> * 转化为标准化元素{/"taskId/":/"t01/",/"sceneId/":/"s01/",/"caseId/":/"cs01/",/"param1/":/"p1/",/"id/":1,/"param10/":/"cpu01/"}<br> * 2.将队列中的jsonstr转换为对应的类实例<br> * 3.调用插入数据库函数将结果插入数据库中<br> * @param jstrCaseLog<br> */<br>public void insertCaseLog(String jstrCaseLog)<br>{<br>List<Object> ls = com.alisoft.testplat.help.JsonFunc.fromJSON(<br>jstrCaseLog, ArrayList.class);<br>//取得数据库中所有的LogParam<br>TestCaseService tss = new TestCaseService();<br>List<LogParam> lp = tss.getLogParamList();<br>List<LinkedHashMap> lstmp = new ArrayList<LinkedHashMap>();<br>LinkedHashMap map = new LinkedHashMap();<br>for (int i = 0; i < ls.size(); i++) {<br>map = (LinkedHashMap) ls.get(i);<br>for (int j = 0; j < map.keySet().size(); j++) {<br>//使用Key去寻找是哪个Param,如果不是那么就返回自己<br>for(int k = 0; k < lp.size(); k++)<br>{<br>LogParam tmplp = lp.get(k);<br>//如果传入的参数别名=某条记录的参数别名,那么替换为该参数实际名称<br>if(map.keySet().toArray()[j].toString().toLowerCase().equals(tmplp.getParamAlias().toLowerCase()))<br>{<br>Object value = map.get(map.keySet().toArray()[j]);<br>map.remove(map.keySet().toArray()[j]);<br>map.put(tmplp.getParamName().toLowerCase(), value);<br>}<br>}<br>}<br>lstmp.add(map);<br>}<br>String tempstr = com.alisoft.testplat.help.JsonFunc.toJSON(lstmp);<br>List<Object> deslp = com.alisoft.testplat.help.JsonFunc.fromJSON(tempstr, ArrayList.class);<br>for(int index = 0; index < deslp.size(); index++)<br>{<br>String cp = getListNode(deslp,index);<br>CaseLog tlp = com.alisoft.testplat.help.JsonFunc.fromJSON(cp, CaseLog.class);<br>CaseLogDao.InsertCaseLog(tlp);<br>}<br>}<br><br>public String getListNode(List<Object> ls,int index)<br>{<br>StringBuilder desstr = new StringBuilder("{");<br>LinkedHashMap map = new LinkedHashMap();<br>map = (LinkedHashMap) ls.get(index);<br>for (int j = 0; j < map.keySet().size(); j++) {<br>//如果传入的参数别名=某条记录的参数别名,那么替换为该参数实际名臣<br>Object key =map.keySet().toArray()[j];<br>Object value = map.get(map.keySet().toArray()[j]);<br>if(j < (map.keySet().size()-1))<br>{<br>if (value != null)<br>{<br>desstr.append("/"").append(key.toString()).append("/":").append("/"").append(value.toString()).append("/"").append(",");<br>}<br>else<br>{<br>desstr.append("/"").append(key.toString()).append("/":").append("null").append(",");<br>}<br>}<br>else<br>{ <br>if (value != null)<br>{<br>desstr.append("/"").append(key.toString()).append("/":").append("/"").append(value.toString()).append("/"").append("}");<br>}<br>else<br>{<br>desstr.append("/"").append(key.toString()).append("/":").append("null").append("}");<br>}<br>}<br>}</p>
<p>System.out.println(desstr.toString());<br>return desstr.toString();<br>}</p>
<p></p>
<p></p>
<p>public static String toJSON(Object obj) {<br> StringWriter writer = new StringWriter();<br> try {<br> mapper.writeValue(writer, obj);<br> } catch (JsonGenerationException e) {<br> throw new RuntimeException(e);<br> } catch (JsonMappingException e) {<br> throw new RuntimeException(e);<br> } catch (IOException e) {<br> throw new RuntimeException(e);<br> }<br> return writer.toString();<br>}<br><br>public static <T> T fromJSON(String json, Class<T> clazz) {<br> ObjectMapper mapper = new ObjectMapper();<br> try {<br> return mapper.readValue(json, clazz);<br> } catch (JsonParseException e) {<br> throw new RuntimeException(e);<br> } catch (JsonMappingException e) {<br> throw new RuntimeException(e);<br> } catch (IOException e) {<br> throw new RuntimeException(e);<br> }<br> }</p>
分享到:
相关推荐
6个目标文件,EJB来模拟银行ATM机的流程及操作:获取系统属性,初始化JNDI,取得Home对象的引用,创建EJB对象,并将当前的计数器初始化,调用每一个EJB对象的count()方法,保证Bean正常被激活和钝化,EJB对象是用...
import android.os.Bundle; import android.os.Handler; import android.os.Looper; import android.support.v7.app.... // 将ContentHandler的实例设置到XMLReader中 xmlReader.setContentHandler(handler); ...
6个目标文件,EJB来模拟银行ATM机的流程及操作:获取系统属性,初始化JNDI,取得Home对象的引用,创建EJB对象,并将当前的计数器初始化,调用每一个EJB对象的count()方法,保证Bean正常被激活和钝化,EJB对象是用...
根据指定条件查询数据集合,调用过程:先实例化一个CalendarNotesModel对象,然后设置筛选条件(即给相应属性字段赋值),然后调用此方法,可通过querytype参数设置筛选出的数据集的排序,如” UpdateTime DESC”,...
根据指定条件查询数据集合,调用过程:先实例化一个CalendarNotesModel对象,然后设置筛选条件(即给相应属性字段赋值),然后调用此方法,可通过querytype参数设置筛选出的数据集的排序,如” UpdateTime DESC”,...
11.3.2 对多个对象使用一个表 453 11.3.3 对一个对象使用多个表 455 11.4 从模型中生成数据库 457 11.5 小结 460 第12章 使用sql server 461 12.1 sql server compact 462 12.1.1 连接sql server ...