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文本
- // 假设现在要创建这样一个json文本
- // {
- // "phone" : ["12345678", "87654321"], // 数组
- // "name" : "yuanzhifei89", // 字符串
- // "age" : 100, // 数值
- // "address" : { "country" : "china", "province" : "jiangsu" }, // 对象
- // "married" : false // 布尔值
- // }
- try {
- // 首先最外层是{},是创建一个对象
- JSONObject person = new JSONObject();
- // 第一个键phone的值是数组,所以需要创建数组对象
- JSONArray phone = new JSONArray();
- phone.put("12345678").put("87654321");
- person.put("phone", phone);
- person.put("name", "yuanzhifei89");
- );
- // 键address的值是对象,所以又要创建一个对象
- JSONObject address = new JSONObject();
- address.put("country", "china");
- address.put("province", "jiangsu");
- person.put("address", address);
- person.put("married", false);
- } catch (JSONException ex) {
- // 键为null或使用json不支持的数字格式(NaN, infinities)
- throw new RuntimeException(ex);
- }
getType和optType api的使用
getType可以将要获取的键的值转换为指定的类型,如果无法转换或没有值则抛出JSONException optType也是将要获取的键的值转换为指定的类型,无法转换或没有值时返回用户提供或这默认提供的值
- try {
- // 所有使用的对象都是用上面创建的对象
- // 将第一个电话号码转换为数值和将名字转换为数值
- );
- person.getLong("name"); // 会抛异常,因为名字无法转换为long
- ); // 代码内置的默认值
- , 1000); // 用户提供的默认值
- person.optLong("name");
- ); // 不像上面那样抛异常,而是返回1000
- } catch (JSONException ex) {
- // 异常处理代码
- }
除了上面的两个类,还可以使用JSONStringer来构建json文本
- try {
- JSONStringer jsonText = new JSONStringer();
- // 首先是{,对象开始。object和endObject必须配对使用
- jsonText.object();
- jsonText.key("phone");
- // 键phone的值是数组。array和endArray必须配对使用
- jsonText.array();
- jsonText.value("12345678").value("87654321");
- jsonText.endArray();
- jsonText.key("name");
- jsonText.value("yuanzhifei89");
- jsonText.key("age");
- );
- jsonText.key("address");
- // 键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();
- // {
- // "phone" : ["12345678", "87654321"], // 数组
- // "name" : "yuanzhifei89", // 字符串
- // "age" : 100, // 数值
- // "address" : { "country" : "china", "province" : "jiangsu" }, // 对象
- // "married" : false // 布尔值
- // }
- 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);
- // 此时还未读取任何json文本,直接读取就是一个JSONObject对象。
- // 如果此时的读取位置在"name" : 了,那么nextValue就是"yuanzhifei89"(String)
- JSONObject person = (JSONObject) jsonParser.nextValue();
- // 接下来的就是JSON对象的操作了
- 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);
- // 继续向下读8个json文本中的字符。此时刚开始,即在{处
- ); //{ "phone。tab算一个字符
- // 继续向下读1个json文本中的字符
- jsonParser.next(); //"
- // 继续向下读取一个json文本中的字符。该字符不是空白、同时也不是注视中的字符
- jsonParser.nextClean(); //:
- // 返回当前的读取位置到第一次遇到'a'之间的字符串(不包括a)。
- jsonParser.nextString('a'); // ["12345678", "87654321"], "n(前面有两个空格)
- // 返回当前读取位置到第一次遇到字符串中(如"0089")任意字符之间的字符串,同时该字符是trimmed的。(此处就是第一次遇到了89)
- jsonParser.nextTo("0089"); //me" : "yuanzhifei
- // 读取位置撤销一个
- jsonParser.back();
- jsonParser.next(); //i
- // 读取位置前进到指定字符串处(包括字符串)
- jsonParser.skipPast("address");
- ); //" : { "c
- // 读取位置前进到执行字符处(不包括字符)
- jsonParser.skipTo('m');
- ); //married"
- } 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); |
11 |
// 得到应答的字符串,这也是一个 JSON 格式保存的数据 |
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) { |
17 |
// String strUrl = "http://10.158.166.110:8080/AndroidServer/JsonServlet"; |
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 !"); |
- js学习篇1--数组
javascript的数组可以包含各种类型的数据. 1. 数组的长度 ,直接用 length 属性; var arr=[1,2,3]; arr.length; js中,直接给数组的length赋值是会 ...
- Tomcat集群配置学习篇-----分布式应用
Tomcat集群配置学习篇-----分布式应用 现目前基于javaWeb开发的应用系统已经比比皆是,尤其是电子商务网站,要想网站发展壮大,那么必然就得能够承受住庞大的网站访问量:大家知道如果服务器访问 ...
- (转载)OC学习篇之---概述
前言 终于开启了OC的学习篇了,之前由于工作上的事,学习就一直搁浅了,不过最近由于各种原因,感觉必须要开启iOS的开发旅程了,不然就老了.因为之前一直是做Android的,所以学习iOS来就没那么费劲 ...
- 《Mysql 公司职员学习篇》 第二章 小A的惊喜
第二章 小A的惊喜 ---- 认识数据库 吃完饭后,小Y和小A回到了家里,并打开电脑开始学习Mysql. 小Y:"小A,你平时的Excell文件很多的情况下,怎么样存放Exce ...
- Java多线程(学习篇)
Java多线程:(学习篇) 1.什么是线程 2.线程状态 3.线程中断 4.线程交互 5.同步机制 6.锁机制 7.堵塞队列与堵塞栈 8.条件变量.原子量.线程池等 9.线性安全类和Callable与 ...
- 鸟哥Linux私房菜基础学习篇学习笔记3
鸟哥Linux私房菜基础学习篇学习笔记3 第十二章 正则表达式与文件格式化处理: 正则表达式(Regular Expression) 是通过一些特殊字符的排列,用以查找.删除.替换一行或多行文字字符: ...
- 鸟哥Linux私房菜基础学习篇学习笔记2
鸟哥Linux私房菜基础学习篇学习笔记2 第九章 文件与文件系统的压缩打包: Linux下的扩展名没有什么特殊的意义,仅为了方便记忆. 压缩文件的扩展名一般为: *.tar, *.tar.gz, *. ...
- 鸟哥Linux私房菜基础学习篇学习笔记1
鸟哥Linux私房菜基础学习篇学习笔记1 第三章 主导分区(MBR),当系统在开机的时候会主动去读取这个区块的内容,必须对硬盘进行分区,这样硬盘才能被有效地使用. 所谓的分区只是针对64Bytes的分 ...
- Scrapy学习篇(十)之下载器中间件(Downloader Middleware)
下载器中间件是介于Scrapy的request/response处理的钩子框架,是用于全局修改Scrapy request和response的一个轻量.底层的系统. 激活Downloader Midd ...
- [Swift2.0系列]Defer/Guard 基础语法
1.Defer Swift2.0中加入了defer新语法声明.defer译为延缓.推迟之意.那么在Swift2.0中它将被应用于什么位置呢?比如,读取某目录下的文件内容并处理数据,你需要首先定位到文件 ...
- Apache虚拟目录(二)
一.PHP生命周期 二.轻量级的PHP 轻量级PHP产品由lighttpd,nginx等等 Apache是基于模块化设计的 了解Apache源代码可以从main.c开始 操作系统上跑了APR运行库 m ...
- Linux下GCC的使用
1简介 GCC 的意思也只是 GNU C Compiler 而已.经过了这么多年的发展,GCC 已经不仅仅能支持 C 语言:它现在还支持 Ada 语言.C++ 语言.Java 语言.Objective ...
- HTML--9表单和验证事件
1.表单验证<form></form> (1).非空验证(去空格) (2).对比验证(跟一个值对比) (3).范围验证(根据一个范围进行判断) (4).固定格式验证:电话号码, ...
- Event Handling on Mac
Keyboard/Mouse Event + Cocoa AppleEvent + Cocoa AppleEvent + CommandLine App(w/o UI) + CoreFoundatio ...
- MATLAB里的正则表达式 [转]
正则表达式在处理字符串及文本时显得十分方便,在perl, python等脚本语言,以及java, .net等平台上都支援正则表达式.事实上,在MATLAB中也提供了正则表达式的支持.主要包含三个常用的 ...
- python3 nonlocal vs global
考虑这样一个python程序: x = 12 def func(): x = 1 func() print(x) 输出为:x = 12 因为函数内部定义的x被认为只属于局部作用域,为了表明我么引用的是 ...
- 创建一个Windows窗体
20140702加: WS_OVERLAPPEDWINDOW这个属性如果写成WS_OVERLAPPED,则窗口没有最大最小按钮以及左边的系统的菜单. vs2010下的代码提示快捷键:CTRL + J ...
- AFNetworking实现程序重新启动时的断点续传
今天需要用AFNetworking实现断点续传的功能,但是在进行了一番研究之后,发现AFNetworking虽然支持下载文件的暂停和继续,但是程序重新启动后再次下载无法进行续传.网上有说可以通过AFD ...
- eval函数的工作原理
如果您想详细了解eval和JSON请参考以下链接: eval :https://developer.mozilla.org/En/Core_JavaScript_1.5_Reference/Glob ...