JSON数据解析(转)

JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,采用完全独立于语言的文本格式,为Web应用开发提供了一种理想的数据交换格式。

  本文将主要介绍在Android开发中,如何在服务器端创建JSON数据,以及如何在Android客户端对JSON数据进行解析。

 

1.JSON数据结构

  在JSON中有两种数据结构:对象和数组。

1.1对象

  在JSON中,一个对象以“{”(左括号)开始,“}”(右括号)结束。每个“名称”后跟一个“:”(冒号),冒号后是该名称的值,多个“名称:值”之间使用 “,”(逗号)分隔开来。名称需要使用双引号括起来,值如果是字符串则必须用双引号括起来,如果是数值型则不需要。其结构示意图如图1所示。

JSON数据解析(转)

图1 JSON对象结构示意图

  如下的代码是一个简单的JSON对象示例:

1   {
2   "id":001,
3   "name":"jack",
4   "age":25
5   }

1.2数组

  在JSON中,数组是值(value)的有序集合。一个数组以“[”(左中括号)开始,“]”(右中括号)结束。值之间使用 “,”(逗号)分隔开来。其结构示意图如图2所示。

JSON数据解析(转)

图2 JSON数组结构示意图

  如下的代码是一个简单的JSON数组示例:

  ["北京","上海","广州"]

1.3值的类型

  在JSON的对象和数组结构中,value值不仅可以是数字、字符串等简单数据类型,还可以是对象、数组等,如图3所示。

JSON数据解析(转)

图3 JSON中值的类型

  因此,我们可以使用对象和数组的组合构成复杂的数据结构。如下的代码使用对象结构定义了一个“students”对象,在“students”对象中包含了一个学生数组,而学生数组中的值又是JSON对象。

JSON数据解析(转)
JSON数据解析(转)
1     {
2         "students":
3         [
4         {"name":"jack","age":23},
5         {"name":"rose","age":24}
6         ]
7     }
JSON数据解析(转)
JSON数据解析(转)

 

2.在服务器端生成JSON数据

  通常,客户端在请求服务器数据时,服务器可以使用XML文档、JSON数据或HTML的形式将数据发送给客户端。

  那么如何在服务器端生成JSON数据呢?首先需要完成以下两个准备工作。

  (1)我们需要使用MyEclipse创建了一个Web Project,这里我将该工程命名为了“JsonDemoProject”,用来模拟服务器端的Web服务。

  (2)我们还需要在该工程中导入JSON的API数据包json-lib-2.2.2-jdk15.jar。

  在JSON的API中,提供了JSONObject类,通过调用JSONObject类的put(Object key, Object value)方法,可以将一个Object对象以键值对的形式存入JSONObject对象。通过调用JSONObject类的toString()方法,则可以将JSONObject对象转化为JSON数据。

  如下的代码创建了一个JsonTools类,并实现了静态方法createJsonString(),用来生成JSON数据。

JSON数据解析(转)
JSON数据解析(转)
 1   public class JsonTools {
 2       
 3       /*
 4        * Function :   生成JSON数据
 5        * Param   :  key        Json数据的键值
 6        *              object     要生成Json数据的内容
 7        * Retuen  :   JSON数据
 8        * Author  :   博客园-依旧淡然
 9        */
10       public static String createJsonString(String key, Object value) {
11           JSONObject jsonObject = new JSONObject();    //创建一个JSONObject对象
12           jsonObject.put(key, value);                  //往JSONObject对象中填入内容
13           return jsonObject.toString();                //生成JSON数据并返回
14       }
15       
16   }
JSON数据解析(转)
JSON数据解析(转)

  通过使用该方法,我们可以很方便的将各种数据传递进来,并将其转化成JSON数据。比如,我们可以在JsonService类中,实现一个简单的获取Person对象列表的方法,具体如下:

JSON数据解析(转)
JSON数据解析(转)
 1     /*
 2      * Function :   获取Person对象列表
 3      * Author  :   博客园-依旧淡然
 4      */
 5     public List<Person> getListPerson() {
 6         List<Person> list = new ArrayList<Person>();
 7         Person person1 = new Person(001, "jack", 25);
 8         Person person2 = new Person(002, "rose", 24);
 9         Person person3 = new Person(003, "bob", 26);
10         list.add(person1);
11         list.add(person2);
12         list.add(person3);
13         return list;
14     }
JSON数据解析(转)
JSON数据解析(转)

  其中,Person对象具有id(int)、name(String)和age(int)三个属性。

  最后,我们可以创建一个继承自HttpServlet的JsonAction类,并实现其中的doPost()方法,用来响应客户端对服务器的请求。具体如下:

JSON数据解析(转)
JSON数据解析(转)
 1   public void doPost(HttpServletRequest request, HttpServletResponse response)
 2             throws ServletException, IOException {
 3 
 4         response.setContentType("text/html;charset=utf-8");
 5         request.setCharacterEncoding("utf-8");
 6         response.setCharacterEncoding("utf-8");
 7         PrintWriter out = response.getWriter();
 8         
 9         List<Person> listPerson = jsonService.getListPerson();
10         
11         String str = null;
12         String action_flag = request.getParameter("action_flag");    //获取URL参数
13         if(action_flag.equals("persons")) {
14             str = JsonTools.createJsonString("persons", listPerson);
15         }
16         out.println(str);
17         out.flush();
18         out.close();
19     }
JSON数据解析(转)
JSON数据解析(转)

  可以看到,在doPost()方法中,我们通过调用getListPerson()方法获得了Person对象列表listPerson,并将其传入JsonTools.createJsonString()方法中,从而获得了一串JSON数据。

  将该工程发布到Tomcat上,使用浏览器访问该Web工程,可以看到如图4所示的界面,Person对象列表被成功的转化成了JSON数据。

JSON数据解析(转)图4 生成的JSON数据

 

3.在客户端解析JSON数据

  通过上面的步骤,我们已经在服务器上生成了JSON数据。要在我们的Android工程中获取该JSON数据是很容易的,只需要利用Android为我们提供的HttpURLConnection接口访问图4所示的URL即可。

  那么,获取到服务器上的JSON数据以后,如何在Android工程中完成对该JSON数据的解析呢?

  观察图4所示的JSON数据可以看出:

  (1)该JSON数据的最外层是JSONObject,JSONObject的键是“persons”,值是一个JSONArray。

  (2)在JSONArray中又包含了3个JSONObject对象。

  (3)而在内嵌的每一个JSONObject对象中,都有3个键值对的组合。

  分析清楚了JSON数据的构成形式之后,就可以开始着手对其进行解析了。在Android工程中,我们可以创建一个JsonTools类,并实现getListPerson()类方法,用来完成把从服务器获得的Json数据解析出来,还原成Person对象列表。具体代码如下所示:

JSON数据解析(转)
JSON数据解析(转)
 1     /*
 2      * Function  :   解析JSON数据,还原成Person对象列表
 3      * Param     :   key            Json数据的键值
 4      *               jsonString     从服务器获得的Json数据
 5      * Retuen   :   Person对象列表
 6      * Author    :   博客园-依旧淡然
 7      */
 8     public static List<Person> getListPerson(String key, String jsonString) {
 9         List<Person> list = new ArrayList<Person>();
10         try {
11             JSONObject jsonObject = new JSONObject(jsonString);          //创建JSONObject对象
12             JSONArray personArray = jsonObject.getJSONArray(key);        //获取JSONObject对象的值,该值是一个JSON数组
13             for(int i = 0; i < personArray.length(); i++) {
14                 JSONObject personObject = personArray.getJSONObject(i);  //获得JSON数组中的每一个JSONObject对象
15                 Person person = new Person();
16                 int id = personObject.getInt("id");                      //获得每一个JSONObject对象中的键所对应的值
17                 String name = personObject.getString("name");
18                 int age = personObject.getInt("age");
19                 person.setId(id);        //将解析出来的属性值存入Person对象
20                 person.setName(name);
21                 person.setAge(age);
22                 list.add(person);        //将解析出来的每一个Person对象添加到List中
23             }
24         } catch (JSONException e) {
25             e.printStackTrace();
26         }
27         return list;
28     }
JSON数据解析(转)
JSON数据解析(转)

  在本实例中,点击Button按钮向服务器发送获取JSON数据的请求,从服务器获得JSON数据后,可以使用以上的代码完成对JSON数据的解析,最后将解析得到的Person对象依次显示在TextView控件中。程序运行的结果如图5所示。

JSON数据解析(转)

 

 

 

转自:链接


本文转自SharkBin博客园博客,原文链接:http://www.cnblogs.com/SharkBin/p/4889910.html,如需转载请自行联系原作者

上一篇:JSON数据解析(GSON方式) (转)


下一篇:使用DTS从RDS PG实时同步数据到AnalyticDB for PostgreSQL