一、JS遍历JSON串

示例01

目标:返回的JSON串中,一个Key对应的Value是一个数组(若在Java程序中,是一个List)。

现在要求获取每个数组中的第一个对象元素中的name属性的值。

测试代码:

//目标:获取每个列表中,第一个对象元素的name属性值.
var result = {
'A': [{
'name': '111',
'gender': '111male',
'place': '河南'
},
{
'name': '222',
'gender': '222female',
'place': '北京'
}], 'B': [{
'name': '333',
'gender': '333male',
'place': '河北'
},
{
'name': '444',
'gender': '444male',
'place': '湖南'
},
{
'name': '555',
'gender': '555male',
'place': '广西'
}]
}; for( var key in result){
//方式一:
//var oneValue = result[key];
//var name = oneValue[0].name;
//console.info(name); //方式二:
var name = result[key][0].name;
console.info(name);
};

运行结果:

111

333

二、Java对象与JSON串的相互转化

(一) 将Java对象转化成JSON字符

工具:fastjson

1、需求01:将List<Map<String, Object>>对象转化成JSON字符串

【代码示例】

 List<Map> rtnMapList = new ArrayList<Map>()
String cSrc = JSONArray.toJSON(paramMapList).toString();
LogUtil.getLogger().info("JSONArray.toJSON()方法,将Java对象转化成JSON串之后的结果:"+cSrc);

【运行结果】

===========原List<Map>结构数据:==========

 [{acDate=2016-06-15,targetTableName=t_acc_subject_provision},{acDate=2016-06-16,targetTableName=t_acc_subject_provision}]

===========JSONArray.toJSON()方法之后的结果:==========

 [{"acDate":"2016-06-15","targetTableName":"t_acc_subject_provision"},{"acDate":"2016-06-16","targetTableName":"t_acc_subject_provision"}]

(二) 将JSON字符串转化成Java对象 [fastjson]

工具:fastjson

1、需求01:将JSON字符串转化为List<Map>对象。

【代码示例】

 @RequestMapping( value = "testFacade")
public void testFacade(HttpServletRequest request, HttpServletResponse response){
String paramStr = "";
try {
InputStream inStream = request.getInputStream();
//(1)解密参数
paramStr = CheckMsg.check(inStream);
//(2)将参数从JSON格式转化成List<Map>类型。
List<Map> paramMapList = JSONArray.parseArray(paramStr, Map.class); //2.返回空Response,防止响应阻塞。
HttpUtil.httpResponse("", response);
} catch (Exception e) {
e.printStackTrace();
}
}

【运行结果】

===========原JSON字符串:==========

 [{"acDate":"2016-06-15","targetTableName":"t_acc_subject_provision"},{"acDate":"2016-06-16","targetTableName":"t_acc_subject_provision"}]

===========将JSON转化成List<Map>结构后的数据:==========

 [{acDate=2016-06-15,targetTableName=t_acc_subject_provision},
{acDate=2016-06-16,targetTableName=t_acc_subject_provision}]

2、需求02:将JSON字符串转化为List<Map<String, Object>>对象。

【代码示例】

 1 @RequestMapping( value = "testFacade")
2 public void testFacade(HttpServletRequest request, HttpServletResponse response){
3 String paramStr = "";
4 try {
5 InputStream inStream = request.getInputStream();
6 //(1)解密参数
7 paramStr = CheckMsg.check(inStream);
8 //(2)将参数从JSON格式转化成List<Map>类型。
9 List<Map<String, Object>> paramMapList = JSON.parseObject(rtnJsonStr, new TypeReference<List<Map<String, Object>>>(){});
10
11 //2.返回空Response,防止响应阻塞。
12 HttpUtil.httpResponse("", response);
13 } catch (Exception e) {
14 e.printStackTrace();
15 }
16 }

【运行结果】

===========原JSON字符串:==========

1 [{"acDate":"2016-06-15","targetTableName":"t_acc_subject_provision"},{"acDate":"2016-06-16","targetTableName":"t_acc_subject_provision"}]

===========将JSON转化成List<Map>结构后的数据:==========

1 [{acDate=2016-06-15,targetTableName=t_acc_subject_provision},
2 {acDate=2016-06-16,targetTableName=t_acc_subject_provision}]

【说明】

JSONArray类和JSON类是第三方组件com.alibaba.fastjson中的类,它们的类全路径名分别为:

com.alibaba.fastjson.JSONArray,com.alibaba.fastjson.JSON

【参考资料】

JSONArray的应用:http://www.cnblogs.com/henryxu/archive/2013/03/10/2952738.html

Java解析JSON数据:http://www.cnblogs.com/henryxu/archive/2013/03/10/2952741.html

JSON官网:http://www.json.org/

【JSON】JSON字符串的操作(不断积累中)的更多相关文章

  1. php大力力 [024节]PHP中的字符串连接操作(2015-08-27)

    2015-08-27 php大力力024.PHP中的字符串连接操作 PHP中的字符串连接操作  阅读:次   时间:2012-03-25 PHP字符串的连接的简单实例 时间:2013-12-30 很多 ...

  2. LoadRunner中字符串的操作

    LoadRunner中字符串的操作 LoadRunner中常用的字符串操作函数有:                strcpy(destination_string, source_string); ...

  3. json和字符串/数组/集合的互相转换の神操作总结

    一:前端字符串转JSON的4种方式 1,eval方式解析,恐怕这是最早的解析方式了. function strToJson(str){ var json = eval('(' + str + ')') ...

  4. Python中json的简单读写操作

    Python中json的简单读写操作 JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式.它基于ECMAScript的一个子集. JSON采用完全独立于语言的 ...

  5. java中json和字符串互转及日期转换 练习

    一:以下是用到的jar名称: commons-beanutils-1.6.jar commons-collections-3.2.1.jar commons-lang-2.6.jar commons- ...

  6. JSON(五)——同步请求中使用JSON格式字符串进行交互(不太常见的用法)

    在同步请求中使用JSON格式进行数据交互的场景并不多,同步请求是浏览器直接与服务器进行数据交互的大多是用jsp的标签jstl和el表达式对请求中的数据进行数据的渲染.我也是在一次开发中要从其它服务器提 ...

  7. JSON(二)——JavaScript中js对象与JSON格式字符串的相互转换

    首先我们来看一下js中JSON格式的字符串 var JSONStr1 = "{\"name\" : \"张三\"}"; 注意以下的写法不是j ...

  8. json数据格式字符串在java中的转移

    说明:项目中遇到请求的json数据字符串,打印出来没有问题,但是想加入到代码中,就需要进行转移 原数据为(用src代替)(没有写完): {"adjust_fee":"0. ...

  9. 在论坛中出现的比较难的sql问题:36(动态行转列 解析json格式字符串)

    原文:在论坛中出现的比较难的sql问题:36(动态行转列 解析json格式字符串) 所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路.

  10. 前台页面中json和字符串相互转化

    比如我有两个变量,我要将a转换成字符串,将b转换成JSON对象: var a={"name":"tom","sex":"男&quo ...

随机推荐

  1. hibernate lazy=false annotation设置

    工程报错如下: org.hibernate.LazyInitializationException: could not initialize proxy - no Session 解决方法: 在类的 ...

  2. UVa 10361 Automatic Poetry

    Automatic Poetry Input: standard input Output: standard output Time Limit: 2 seconds Memory Limit: 3 ...

  3. Windows系统下Memcached缓存系列一:Couchbase(服务器端)和CouchbaseClient(c#客户端)的安装教程

    一:服务器端的安装  官网 http://www.couchbase.com/download  我的电脑是64位的win7,找到对应下载windows版本的服务器端缓存,大概90M的样子 运行期间可 ...

  4. UVA 11383 Golden Tiger Claw(最佳二分图完美匹配)

    题意:在一个N*N的方格中,各有一个整数w(i,j),现在要求给每行构造row(i),给每列构造col(j),使得任意w(i,j)<=row(i)+col(j),输出row(i)与col(j)之 ...

  5. 点分十进制IP校验、转换,掩码校验

    /***************************************************************************** * 点分十进制IP校验.转换,掩码校验 * ...

  6. java金额的加减乘除

    package com.wedge.edp.framework.common.util; import java.math.BigDecimal; /** * 金额的加减乘除 */ public cl ...

  7. 【英语】Bingo口语笔记(55) - work系列

  8. Java中HashMap的数据结构

    类声明: 概述: 线程不安全: <Key, Value>两者都可以为null: 不保证映射的顺序,特别是它不保证该顺序恒久不变: HashMap使用Iterator: HashMap中ha ...

  9. Android堆栈分析

    在开发中,与界面跳转联系比较紧密的概念是Task(任务)和Back Stack(回退栈).activity的启动模式会影响Task和Back Stack的状态, 进而影响用户体验.除了启动模式之外,I ...

  10. suse下设置IP的两种方法

    /Files/yzhxhwt/DB_51aspx.rar 第一种SUSE Linux IP设置方法ifconfig eth0 192.168.1.22 netmask 255.255.255.0 up ...