现在的位置: 首页 > 综合 > 正文

Android Json生成及解析实例

2014年06月07日 ⁄ 综合 ⁄ 共 3447字 ⁄ 字号 评论关闭


JSON的定义:

       一种轻量级的数据交换格式,具有良好的可读和便于快速编写的特性。业内主流技术为其提供了完整的解决方案(有点类似于正则表达式 ,获得了当今大部分语言的支持),从而可以在不同平台间进行数据交换。JSON采用兼容性很高的文本格式,同时也具备类似于C语言体系的行为。

JSON Vs XML

1.JSON和XML的数据可读性基本相同

2.JSON和XML同样拥有丰富的解析手段

3.JSON相对于XML来讲,数据的体积小

4.JSON与JavaScript的交互更加方便

5.JSON对数据的描述性比XML较差

6.JSON的速度要远远快于XML

android2.3提供的json解析类 

android的json解析部分都在包org.json下,主要有以下几个类: 

JSONObject:可以看作是一个json对象,这是系统中有关JSON定义的基本单元,其包含一对儿(Key/Value)数值。它对外部(External
  应用
toString()方法输出的数值)调用的响应体现为一个标准的字符串(例如:{"JSON":
"Hello, World"}
,最外被大括号包裹,其中的KeyValue被冒号":"分隔)。其对于内部(Internal)行为的操作格式略微,例如:初始化一个JSONObject实例,引用内部的put()方法添加数值:new
JSONObject().put("JSON", "Hello, World!")
,在KeyValue之间是以逗号","分隔。
Value的类型包括:BooleanJSONArrayJSONObjectNumberString或者默认值JSONObject.NULL
object 。

JSONStringer:json文本构建类
,根据官方的解释,这个类可以帮助快速和便捷的创建JSON text。其最大的优点在于可以减少由于 格式的错误导致程序异常,引用这个类可以自动严格按照JSON语法规则(syntax rules)创建JSON text。每个JSONStringer实体只能对应创建一个JSON text。。其最大的优点在于可以减少由于格式的错误导致程序异常,引用这个类可以自动严格按照JSON语法规则(syntax
rules)创建JSON text。每个JSONStringer实体只能对应创建一个JSON text。

JSONArray它代表一组有序的数值。将其转换为String输出(toString)所表现的形式是用方括号包裹,数值以逗号”,”分隔(例如:
    [value1,value2,value3],大家可以亲自利用简短的代码更加直观的了解其格式)。这个类的内部同样具有查询行为,     get()和opt()两种方法都可以通过index索引返回指定的数值,put()方法用来添加或者替换数值。
同样这个类的value类型可以包括:Boolean、JSONArray、JSONObject、Number、String或者默认值JSONObject.NULL
object。

JSONTokener:json解析类 
JSONException:json中用到的异常 


         下面来个JSON生成及解析的实例:

          

/**
 * JSON操作类。
 * @author E
 */
public class JsonUtil {
	
	/**
	 * 将数组转换为JSON格式的数据。
	 * @param stoneList 数据源
	 * @return JSON格式的数据
	 */
	public static String changeArrayDateToJson(ArrayList<Stone> stoneList){
		try {
			JSONArray array = new JSONArray();
			JSONObject object = new JSONObject();
			int length = stoneList.size();
			for (int i = 0; i < length; i++) {
				Stone stone = stoneList.get(i);
				String name = stone.getName();
				String size = stone.getSize();
				JSONObject stoneObject = new JSONObject();
				stoneObject.put("name", name);
				stoneObject.put("size", size);
				array.put(stoneObject);
			}
			object.put("stones", array);
			return object.toString();
		} catch (JSONException e) {
			e.printStackTrace();
		}
		return null;
	}
	
	/**
	 * 将JSON转化为数组并返回。
	 * @param Json
	 * @return ArrayList<Stone>
	 */
	public static ArrayList<Stone> changeJsonToArray(String Json){
		ArrayList<Stone> gameList = new ArrayList<Stone>();
		try {
			JSONObject jsonObject = new JSONObject(Json);
			if (!jsonObject.isNull("stones")) {
				String aString = jsonObject.getString("stones");
				JSONArray aJsonArray = new JSONArray(aString);
				int length = aJsonArray.length();
				for (int i = 0; i < length; i++) {
					JSONObject stoneJson = aJsonArray.getJSONObject(i);
					String name = stoneJson.getString("name");
					String size = stoneJson.getString("size");
					Stone stone = new Stone();
					stone.setName(name);
					stone.setSize(size);
					gameList.add(stone);
				}
			}
		} catch (Exception e) {
			e.printStackTrace();
		}
		return gameList;
	}

}

写好方法后,就可以引用 了,如下:

import java.util.ArrayList;
import android.app.Activity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;

public class MainActivity extends Activity {

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.main);
		findViewById(R.id.test).setOnClickListener(new View.OnClickListener() {
			@Override
			public void onClick(View v) {
				init();
			}
		});

	}
	
	private void init(){
		ArrayList<Stone> list = new ArrayList<Stone>();
		for (int i = 0; i < 5; i++) {
			Stone stone = new Stone();
			stone.setName("Name" +i);
			stone.setSize("Size" + i);
			list.add(stone);
		}
		String json = JsonUtil.changeArrayDateToJson(list);
		Log.e("JSON", json);
	}

}

再看日志,就看到了生成的JSON数据:


{"stones":[{"size":"Size0","name":"Name0"},{"size":"Size1","name":"Name1"},{"size":"Size2","name":"Name2"},{"size":"Size3","name":"Name3"},{"size":"Size4","name":"Name4"}]}

以上就是如何生成JSON数据,解析请参照第二个方法。



          

抱歉!评论已关闭.