编辑检验json的网站:http://www.bejson.com/go.php?u=http://www.bejson.com/demo2.php
基础结构
JSON建构有两种结构:
[1]
json简单说就是javascript中的对象和数组,所以这两种结构就是对象和数组2种结构,通过这两种结构可以表示各种复杂的结构
1、对象:对象在js中表示为“{}”扩起来的内容,数据结构为 {key:value,key:value,...}的键值对的结构,在面向对象的语言中,key为对象的属性,value为对应的属性值,所以很容易理解,取值方法为 对象.key 获取属性值,这个属性值的类型可以是 数字、字符串、数组、对象几种。
2、数组:数组在js中是中括号“[]”扩起来的内容,数据结构为 [" java","javascript","vb",...],取值方式和所有语言中一样,使用索引获取,字段值的类型可以是 数字、字符串、数组、对象几种。
经过对象、数组2种结构就可以组合成复杂的数据结构了。
编辑本段基础示例
简单地说
[1] ,JSON 可以将 JavaScript 对象中表示的一组数据转换为字符串,然后就可以在函数之间轻松地传递这个字符串,或者在异步应用程序中将字符串从 Web 客户机传递给服务器端程序。这个字符串看起来有点儿古怪,但是 JavaScript很容易解释它,而且 JSON 可以表示比"名称 / 值对"更复杂的结构。例如,可以表示 数组和复杂的对象,而不仅仅是键和值的简单列表。
名称 / 值对
按照最简单的形式,可以用下面这样的 JSON 表示"名称 / 值对":
{ "firstName": "Brett" }
这个示例非常基本,而且实际上比等效的纯文本"名称 / 值对"占用更多的空间:
firstName=Brett
但是,当将多个"名称 / 值对"串在一起时,JSON 就会体现出它的价值了。首先,可以创建包含多个"名称 / 值对"的 记录,比如:
{ "firstName": "Brett", "lastName":"McLaughlin", "email": "aaaa" }
从语法方面来看,这与"名称 / 值对"相比并没有很大的优势,但是在这种情况下 JSON 更容易使用,而且可读性更好。例如,它明确地表示以上三个值都是同一记录的一部分;花括号使这些值有了某种联系。
表示数组
当需要表示一组值时,JSON 不但能够提高可读性,而且可以减少复杂性。例如,假设您希望表示一个人名列表。在 XML中,需要许多开始标记和结束标记;如果使用典型的名称 / 值对(就像在本系列前面文章中看到的那种名称 / 值对),那么必须建立一种专有的数据格式,或者将键名称修改为 person1-firstName这样的形式。
如果使用 JSON,就只需将多个带花括号的记录分组在一起:
{ "people": [
{ "firstName": "Brett", "lastName":"McLaughlin", "email": "aaaa" },
{ "firstName": "Jason", "lastName":"Hunter", "email": "bbbb"},
{ "firstName": "Elliotte", "lastName":"Harold", "email": "cccc" }
]}
这不难理解。在这个示例中,只有一个名为 people的 变量,值是包含三个条目的 数组,每个条目是一个人的记录,其中包含名、姓和 电子邮件地址。上面的示例演示如何用括号将记录组合成一个值。当然,可以使用相同的语法表示多个值(每个值包含多个记录):
{ "programmers": [
{ "firstName": "Brett", "lastName":"McLaughlin", "email": "aaaa" },
{ "firstName": "Jason", "lastName":"Hunter", "email": "bbbb" },
{ "firstName": "Elliotte", "lastName":"Harold", "email": "cccc" }
],
"authors": [
{ "firstName": "Isaac", "lastName": "Asimov", "genre": "science fiction" },
{ "firstName": "Tad", "lastName": "Williams", "genre": "fantasy" },
{ "firstName": "Frank", "lastName": "Peretti", "genre": "christian fiction" }
],
"musicians": [
{ "firstName": "Eric", "lastName": "Clapton", "instrument": "guitar" },
{ "firstName": "Sergei", "lastName": "Rachmaninoff", "instrument": "piano" }
] }
这里最值得注意的是,能够表示多个值,每个值进而包含多个值。但是还应该注意,在不同的主条目(programmers、authors 和 musicians)之间,记录中实际的名称 / 值对可以不一样。JSON 是完全动态的,允许在 JSON 结构的中间改变表示数据的方式。
JSON的定义:
一种轻量级的数据交换格式,具有良好的可读和便于快速编写的特性。业内主流技术为其提供了完整的解决方案(有点类似于正则表达式 ,获得了当今大部分语言的支持),从而可以在不同平台间进行数据交换。JSON采用兼容性很高的文本格式,同时也具备类似于C语言体系的行为。 – Json.org
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"},最外被大括号包裹,其中的Key和Value被冒号":"分隔)。其对于内部(Internal)行为的操作格式略微,例如:初始化一个JSONObject实例,引用内部的put()方法添加数值:new JSONObject().put("JSON", "Hello, World!"),在Key和Value之间是以逗号","分隔。Value的类型包括:Boolean、JSONArray、JSONObject、Number、String或者默认值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中用到的异常
JSONObject, JSONArray来构建json文本
-
-
-
-
-
-
-
-
-
- try {
-
- JSONObject person = new JSONObject();
-
- JSONArray phone = new JSONArray();
- phone.put("12345678").put("87654321");
- person.put("phone", phone);
-
- person.put("name", "yuanzhifei89");
- person.put("age", 100);
-
- JSONObject address = new JSONObject();
- address.put("country", "china");
- address.put("province", "jiangsu");
- person.put("address", address);
- person.put("married", false);
- } catch (JSONException ex) {
-
- throw new RuntimeException(ex);
- }
getType和optType api的使用
getType可以将要获取的键的值转换为指定的类型,如果无法转换或没有值则抛出JSONException
optType也是将要获取的键的值转换为指定的类型,无法转换或没有值时返回用户提供或这默认提供的值
- try {
-
-
- phone.getLong(0);
- person.getLong("name");
- phone.optLong(0);
- phone.optLong(0, 1000);
- person.optLong("name");
- person.optLong("name", 1000);
- } catch (JSONException ex) {
-
- }
除了上面的两个类,还可以使用JSONStringer来构建json文本
- try {
- JSONStringer jsonText = new JSONStringer();
-
- jsonText.object();
-
- jsonText.key("phone");
-
- jsonText.array();
- jsonText.value("12345678").value("87654321");
- jsonText.endArray();
-
- jsonText.key("name");
- jsonText.value("yuanzhifei89");
- jsonText.key("age");
- jsonText.value(100);
-
- jsonText.key("address");
-
- jsonText.object();
- jsonText.key("country");
- jsonText.value("china");
- jsonText.key("province");
- jsonText.value("jiangsu");
- jsonText.endObject();
-
- jsonText.key("married");
- jsonText.value(false);
-
-
- jsonText.endObject();
- } catch (JSONException ex) {
- throw new RuntimeException(ex);
- }
json文本解析类JSONTokener
按照RFC4627规范将json文本解析为相应的对象。
对于将json文本解析为对象,只需要用到该类的两个api:
构造函数
public Object nextValue();
-
-
-
-
-
-
-
-
- private static final String JSON =
- "{" +
- " \"phone\" : [\"12345678\", \"87654321\"]," +
- " \"name\" : \"yuanzhifei89\"," +
- " \"age\" : 100," +
- " \"address\" : { \"country\" : \"china\", \"province\" : \"jiangsu\" }," +
- " \"married\" : false," +
- "}";
-
- try {
- JSONTokener jsonParser = new JSONTokener(JSON);
-
-
- JSONObject person = (JSONObject) jsonParser.nextValue();
-
- person.getJSONArray("phone");
- person.getString("name");
- person.getInt("age");
- person.getJSONObject("address");
- person.getBoolean("married");
- } catch (JSONException ex) {
-
- }
其它的api基本就是用来查看json文本中的文本的
- try {
- JSONTokener jsonParser = new JSONTokener(JSON);
-
- jsonParser.next(8);
-
-
- jsonParser.next();
-
-
- jsonParser.nextClean();
-
-
- jsonParser.nextString('a');
-
-
- jsonParser.nextTo("0089");
-
-
- jsonParser.back();
- jsonParser.next();
-
-
- jsonParser.skipPast("address");
- jsonParser.next(8);
-
-
- jsonParser.skipTo('m');
- jsonParser.next(8);
- } catch (JSONException ex) {
-
- }
以下是一个标准的JSON请求实现过程:
01 |
HttpPost request = new HttpPost(url); |
03 |
JSONObject param = new JSONObject(); |
04 |
param.put( "name" , "rarnu" ); |
05 |
param.put( "password" , "123456" ); |
07 |
StringEntity se = new StringEntity(param.toString()); |
08 |
request.setEntity(se); |
10 |
HttpResponse httpResponse = new DefaultHttpClient().execute(request); |
12 |
String retSrc = EntityUtils.toString(httpResponse.getEntity()); |
14 |
JSONObject result = new JSONObject( retSrc); |
15 |
String token = result.get( "token" ); |
下面这个是自己修改别人的小例子,主要是加一些注释和讲解,这个例子主要是使用android进行json解析。
1 |
单数据{'singer':{'id':01,'name':'tom','gender':'男'}} |
3 |
{'id':02,'name':'tom','gender':'男'}, |
4 |
{'id':03,'name':'jerry,'gender':'男'}, |
5 |
{'id':04,'name':'jim,'gender':'男'}, |
6 |
{'id':05,'name':'lily,'gender':'女'}]} |
下面的类主要是解析单个数据parseJson()和多个数据的方法parseJsonMulti():
01 |
public class JsonActivity extends Activity { |
02 |
/** Called when the activity is first created. */ |
03 |
private TextView tvJson; |
04 |
private Button btnJson; |
05 |
private Button btnJsonMulti; |
07 |
public void onCreate(Bundle savedInstanceState) { |
08 |
super .onCreate(savedInstanceState); |
09 |
setContentView(R.layout.main); |
10 |
tvJson = (TextView) this .findViewById(R.id.tvJson); |
11 |
btnJson = (Button) this .findViewById(R.id.btnJson); |
12 |
btnJsonMulti = (Button) this .findViewById(R.id.btnJsonMulti); |
13 |
btnJson.setOnClickListener( new View.OnClickListener() { |
15 |
public void onClick(View v) { |
18 |
String strUrl = ServerPageUtil.getStrUrl(UrlsOfServer.JSON_SINGER); |
20 |
String strResult = connServerForResult(strUrl); |
25 |
btnJsonMulti.setOnClickListener( new View.OnClickListener() { |
27 |
public void onClick(View v) { |
28 |
String strUrl = ServerPageUtil.getStrUrl(UrlsOfServer.JSON_SINGERS); |
29 |
String strResult = connServerForResult(strUrl); |
31 |
parseJsonMulti(strResult); |
35 |
private String connServerForResult(String strUrl) { |
37 |
HttpGet httpRequest = new HttpGet(strUrl); |
38 |
String strResult = "" ; |
41 |
HttpClient httpClient = new DefaultHttpClient(); |
43 |
HttpResponse httpResponse = httpClient.execute(httpRequest); |
44 |
if (httpResponse.getStatusLine().getStatusCode() == HttpStatus.SC_OK) { |
46 |
strResult = EntityUtils.toString(httpResponse.getEntity()); |
48 |
} catch (ClientProtocolException e) { |
49 |
tvJson.setText( "protocol error" ); |
51 |
} catch (IOException e) { |
52 |
tvJson.setText( "IO error" ); |
58 |
private void parseJson(String strResult) { |
60 |
JSONObject jsonObj = new JSONObject(strResult).getJSONObject( "singer" ); |
61 |
int id = jsonObj.getInt( "id" ); |
62 |
String name = jsonObj.getString( "name" ); |
63 |
String gender = jsonObj.getString( "gender" ); |
64 |
tvJson.setText( "ID号" +id + ", 姓名:" + name + ",性别:" + gender); |
65 |
} catch (JSONException e) { |
66 |
System.out.println( "Json parse error" ); |
71 |
private void parseJsonMulti(String strResult) { |
73 |
JSONArray jsonObjs = new JSONObject(strResult).getJSONArray( "singers" ); |
75 |
for ( int i = 0 ; i < jsonObjs.length() ; i++){ |
76 |
JSONObject jsonObj = ((JSONObject)jsonObjs.opt(i)) |
77 |
.getJSONObject( "singer" ); |
78 |
int id = jsonObj.getInt( "id" ); |
79 |
String name = jsonObj.getString( "name" ); |
80 |
String gender = jsonObj.getString( "gender" ); |
81 |
s += "ID号" +id + ", 姓名:" + name + ",性别:" + gender+ "\n" ; |
84 |
} catch (JSONException e) { |
85 |
System.out.println( "Jsons parse error !" ); |