待解析的JSON格式的文件如下:

    [{"id":"5", "version":"1.0", "name":"xiaowang"},

    {"id":"10", "version":"2.0", "name":"lisi"}]

一、使用JSONObject来解析JSON数据

  官方提供的,所有不需要导入第三方jar包;直接上代码,如下:

 //方法一:使用JSONObject
private void parseJSONWithJSONObject(String JsonData) {
try
{
JSONArray jsonArray = new JSONArray(jsonData);
for (int i=0; i < jsonArray.length(); i++) {
JSONObject jsonObject = jsonArray.getJSONObject(i);
String id = jsonObject.getString("id");
String name = jsonObject.getString("name");
String version = jsonObect.getString("version"); System.out.println("id" + id + ";name" + name + ";version" + version);
}
}
catch (Exception e)
{
e.printStackTrace();
}
}

  步骤解读:

     定义一个JSON数组,用于将服务器返回的数据传入到一个JSONArray对象中; 然后循环遍历这个JSONArray,

   从中取出每一个元素(JSONObject对象),接下来只需调用getString()方法即可将数据取出。

二、使用GSON

  使用该方法解析JSON数据,首先需要添加GSON的jar包;下载地址是:http://download.csdn.net/detail/a924571572/5824225

    需要导入的jar包如图: 

  下面是核心代码:

//方法二:使用GSON
private void parseJSONWithGSON(String JsonData) {
Gson gson = new Gson();
List<App> applist = gson.fromJson(jsonData,
new TypeToken<List<App>>() {}.getType());
for(App app : applist) {
System.out.println("id" + app.getId() + ";name" + app.getName() + ";version" + app.getVersion());
}
}

  步骤解读:

   根据JSON数据内容需要定义一个类,用存放数据,如App类:

public class App {
private String id;
private String name;
private String version; public String getId() {
return id;
} public void setId(String id) {
this.id = id;
} //......
}

     如只有一组数据,则可以直接调用如下代码     

GSON gson = new GSON();
App app = gson.fromJson(jsonData, App.class);

     如果有多组数据,则需要借助TypeToken将期望解析成的数据类型传入fromJson()方法中:

List<App> app = gson.fromJson(jsonData, new TypeToken<<List<App>>> ().getType());

    之后直接使用App对象的方法,如:getId、getName....即可获取数据

  补充:

   TypeToken是什么呢?

    TypeToken的使用非常简单,如上面的代码,只要将需要获取类型的泛型类作为TypeToken的泛型参数构造一个匿名的子类,就可以通过getType()方法获取到我们使用的泛型类的泛型参数类型。

三、使用Jackson

  第三方的工具知道该怎么处理了吧,jar包的下载地址:http://wiki.fasterxml.com/JacksonDownload

    其中需要使用到:

      jackson-databind.jar   核心包(必须),提供基于“流模式”解析的API【JsonPaser(json流读取),JsonGenerator(json流输出)】

        jackson-annotations.jar   数据绑定包(可选),提供基于“对象绑定”和“树模型”相关API。【ObjectMapper,JsonNode(树节点)】

      jackson-core.jar  注解包(可选),提供注解功能。

   核心方法:

public static void parseJSONWithJackson(String jsonData) {
ObjectMapper mapper = new ObjectMapper();
try {
App app = mapper.readValue(jsonData, App.class);
     System.out.println("id" + app.getId() + ";name" + app.getName() + ";version" + app.getVersion());
   } catch (JsonParseException e) {
     e.printStackTrace();
  } catch (JsonMappingException e) {
     e.printStackTrace();
  } catch (IOException e) {
     e.printStackTrace();
   }
}

四、使用Fastjson
  不多说,直接上jar包下载地址:http://download.csdn.net/download/finaljia/5293875

  核心代码:

JSONArray jarr = JSONArray.parseArray(jsonData); //JSON.parseArray(jsonStr);
for (Iterator iterator = jarr.iterator(); iterator.hasNext(); ) {
JSONObject job = (JSONObject)iterator.next();
String id = job.get("id").toString();
String name = job.get("name").toString();
String version = job.get("version").toString();
System.out.println("id" + id + ";name" + name + ";version" + version);
}

最新文章

  1. Go语言实战
  2. Matlab中double,im2double,mat2gray区别
  3. Indexed 和 Stored 的区别
  4. 用JS实现的类似QQ密码的输入特效
  5. hpunix下11gRac的安装
  6. SQL Server 判定时间是否在某个时间区间内
  7. CocoaPods:管理Objective-c 程序中各种第三方开源库关联
  8. snprintf/strncpy/strlcpy速度测试
  9. MVC validation
  10. leetcode 111 Minimum Depth of Binary Tree ----- java
  11. Javascript:作用域 学习总结
  12. [转载]【虚拟化系列】VMware vSphere 5.1 虚拟机管理
  13. ICG_System之全自动代码生成器V2.0版本
  14. 01 Java jdk环境配置
  15. SQL Server - DISTINCT
  16. python panda::dataframe常用操作
  17. 接口自动化框架(java)--3.get,delete请求,Excel管理多种请求类型
  18. Git 将代码回到指定版本
  19. mysql学习笔记--数据库单表查询
  20. ABP .NET corej 版本 第一篇

热门文章

  1. poj 3250 Bad Hair Day (单调栈)
  2. U盘、移动硬盘提示格式化的处理
  3. YARN加载本地库抛出Unable to load native-hadoop library解决办法
  4. sort()排序
  5. 对C语言中sizeof细节的三点分析
  6. 静态分析安全测试(SAST)优缺点探析
  7. mysql 监控工具monyog使用总结
  8. loadrunner 脚本和replaylog中的中文乱码问题(转载)
  9. perl + 匹配前导模式一次或者多次
  10. Item Import: What Does &quot;Sync&quot; Items Do? (Doc ID 417887.1)