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文本

  1. // 假设现在要创建这样一个json文本
  2. //  {
  3. //      "phone" : ["12345678", "87654321"], // 数组
  4. //      "name" : "yuanzhifei89", // 字符串
  5. //      "age" : 100, // 数值
  6. //      "address" : { "country" : "china", "province" : "jiangsu" }, // 对象
  7. //      "married" : false // 布尔值
  8. //  }
  9. try {
  10. // 首先最外层是{},是创建一个对象
  11. JSONObject person = new JSONObject();
  12. // 第一个键phone的值是数组,所以需要创建数组对象
  13. JSONArray phone = new JSONArray();
  14. phone.put("12345678").put("87654321");
  15. person.put("phone", phone);
  16. person.put("name", "yuanzhifei89");
  17. person.put("age", 100);
  18. // 键address的值是对象,所以又要创建一个对象
  19. JSONObject address = new JSONObject();
  20. address.put("country", "china");
  21. address.put("province", "jiangsu");
  22. person.put("address", address);
  23. person.put("married", false);
  24. } catch (JSONException ex) {
  25. // 键为null或使用json不支持的数字格式(NaN, infinities)
  26. throw new RuntimeException(ex);
  27. }

getType和optType api的使用

getType可以将要获取的键的值转换为指定的类型,如果无法转换或没有值则抛出JSONException 

optType也是将要获取的键的值转换为指定的类型,无法转换或没有值时返回用户提供或这默认提供的值

  1. try {
  2. // 所有使用的对象都是用上面创建的对象
  3. // 将第一个电话号码转换为数值和将名字转换为数值
  4. phone.getLong(0);
  5. person.getLong("name"); // 会抛异常,因为名字无法转换为long
  6. phone.optLong(0); // 代码内置的默认值
  7. phone.optLong(0, 1000); // 用户提供的默认值
  8. person.optLong("name");
  9. person.optLong("name", 1000); // 不像上面那样抛异常,而是返回1000
  10. } catch (JSONException ex) {
  11. // 异常处理代码
  12. }

除了上面的两个类,还可以使用JSONStringer来构建json文本

  1. try {
  2. JSONStringer jsonText = new JSONStringer();
  3. // 首先是{,对象开始。object和endObject必须配对使用
  4. jsonText.object();
  5. jsonText.key("phone");
  6. // 键phone的值是数组。array和endArray必须配对使用
  7. jsonText.array();
  8. jsonText.value("12345678").value("87654321");
  9. jsonText.endArray();
  10. jsonText.key("name");
  11. jsonText.value("yuanzhifei89");
  12. jsonText.key("age");
  13. jsonText.value(100);
  14. jsonText.key("address");
  15. // 键address的值是对象
  16. jsonText.object();
  17. jsonText.key("country");
  18. jsonText.value("china");
  19. jsonText.key("province");
  20. jsonText.value("jiangsu");
  21. jsonText.endObject();
  22. jsonText.key("married");
  23. jsonText.value(false);
  24. // },对象结束
  25. jsonText.endObject();
  26. } catch (JSONException ex) {
  27. throw new RuntimeException(ex);
  28. }

json文本解析类JSONTokener
 


按照RFC4627规范将json文本解析为相应的对象。

对于将json文本解析为对象,只需要用到该类的两个api:
 


构造函数 


public Object nextValue();

  1. //  {
  2. //      "phone" : ["12345678", "87654321"], // 数组
  3. //      "name" : "yuanzhifei89", // 字符串
  4. //      "age" : 100, // 数值
  5. //      "address" : { "country" : "china", "province" : "jiangsu" }, // 对象
  6. //      "married" : false // 布尔值
  7. //  }
  8. private static final String JSON =
  9. "{" +
  10. "   \"phone\" : [\"12345678\", \"87654321\"]," +
  11. "   \"name\" : \"yuanzhifei89\"," +
  12. "   \"age\" : 100," +
  13. "   \"address\" : { \"country\" : \"china\", \"province\" : \"jiangsu\" }," +
  14. "   \"married\" : false," +
  15. "}";
  16. try {
  17. JSONTokener jsonParser = new JSONTokener(JSON);
  18. // 此时还未读取任何json文本,直接读取就是一个JSONObject对象。
  19. // 如果此时的读取位置在"name" : 了,那么nextValue就是"yuanzhifei89"(String)
  20. JSONObject person = (JSONObject) jsonParser.nextValue();
  21. // 接下来的就是JSON对象的操作了
  22. person.getJSONArray("phone");
  23. person.getString("name");
  24. person.getInt("age");
  25. person.getJSONObject("address");
  26. person.getBoolean("married");
  27. } catch (JSONException ex) {
  28. // 异常处理代码
  29. }

其它的api基本就是用来查看json文本中的文本的

代码

  1. try {
  2. JSONTokener jsonParser = new JSONTokener(JSON);
  3. // 继续向下读8个json文本中的字符。此时刚开始,即在{处
  4. jsonParser.next(8); //{    "phone。tab算一个字符
  5. // 继续向下读1个json文本中的字符
  6. jsonParser.next(); //"
  7. // 继续向下读取一个json文本中的字符。该字符不是空白、同时也不是注视中的字符
  8. jsonParser.nextClean(); //:
  9. // 返回当前的读取位置到第一次遇到'a'之间的字符串(不包括a)。
  10. jsonParser.nextString('a'); //  ["12345678", "87654321"],    "n(前面有两个空格)
  11. // 返回当前读取位置到第一次遇到字符串中(如"0089")任意字符之间的字符串,同时该字符是trimmed的。(此处就是第一次遇到了89)
  12. jsonParser.nextTo("0089"); //me" : "yuanzhifei
  13. // 读取位置撤销一个
  14. jsonParser.back();
  15. jsonParser.next(); //i
  16. // 读取位置前进到指定字符串处(包括字符串)
  17. jsonParser.skipPast("address");
  18. jsonParser.next(8); //" : { "c
  19. // 读取位置前进到执行字符处(不包括字符)
  20. jsonParser.skipTo('m');
  21. jsonParser.next(8); //married"
  22. } catch (JSONException ex) {
  23. // 异常处理代码
  24. }

以下是一个标准的JSON请求实现过程:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
HttpPost request = new HttpPost(url); 
// 先封装一个 JSON 对象 
JSONObject param = new JSONObject(); 
param.put("name", "rarnu"); 
param.put("password", "123456"); 
// 绑定到请求 Entry 
StringEntity se = new StringEntity(param.toString());  
request.setEntity(se); 
// 发送请求 
HttpResponse httpResponse = new DefaultHttpClient().execute(request); 
// 得到应答的字符串,这也是一个 JSON 格式保存的数据 
String retSrc = EntityUtils.toString(httpResponse.getEntity()); 
// 生成 JSON 对象 
JSONObject result = new JSONObject( retSrc); 
String token = result.get("token");

下面这个是自己修改别人的小例子,主要是加一些注释和讲解,这个例子主要是使用android进行json解析。

1
2
3
4
5
6
单数据{'singer':{'id':01,'name':'tom','gender':'男'}}
多个数据{"singers":[
        {'id':02,'name':'tom','gender':'男'},
         {'id':03,'name':'jerry,'gender':'男'},
{'id':04,'name':'jim,'gender':'男'},
{'id':05,'name':'lily,'gender':'女'}]}

下面的类主要是解析单个数据parseJson()和多个数据的方法parseJsonMulti():

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
public class JsonActivity extends Activity { 
    /** Called when the activity is first created. */ 
    private TextView tvJson; 
    private Button btnJson; 
    private Button btnJsonMulti; 
    @Override 
    public void onCreate(Bundle savedInstanceState) { 
        super.onCreate(savedInstanceState); 
        setContentView(R.layout.main); 
        tvJson = (TextView) this.findViewById(R.id.tvJson); 
        btnJson = (Button) this.findViewById(R.id.btnJson); 
        btnJsonMulti = (Button) this.findViewById(R.id.btnJsonMulti); 
        btnJson.setOnClickListener(new View.OnClickListener() { 
            @Override 
            public void onClick(View v) { 
                // url 
                // String strUrl = "http://10.158.166.110:8080/AndroidServer/JsonServlet"; 
                String strUrl = ServerPageUtil.getStrUrl(UrlsOfServer.JSON_SINGER); 
                //获得返回的Json字符串 
                String strResult = connServerForResult(strUrl); 
                //解析Json字符串 
                parseJson(strResult); 
            
        }); 
        btnJsonMulti.setOnClickListener(new View.OnClickListener() { 
            @Override 
            public void onClick(View v) { 
                String strUrl = ServerPageUtil.getStrUrl(UrlsOfServer.JSON_SINGERS); 
                String strResult = connServerForResult(strUrl); 
                //获得多个Singer 
                parseJsonMulti(strResult); 
            
        }); 
    
    private String connServerForResult(String strUrl) { 
        // HttpGet对象 
        HttpGet httpRequest = new HttpGet(strUrl); 
        String strResult = ""
        try
            // HttpClient对象 
            HttpClient httpClient = new DefaultHttpClient(); 
            // 获得HttpResponse对象 
            HttpResponse httpResponse = httpClient.execute(httpRequest); 
            if (httpResponse.getStatusLine().getStatusCode() == HttpStatus.SC_OK) { 
                // 取得返回的数据 
                strResult = EntityUtils.toString(httpResponse.getEntity()); 
            
        } catch (ClientProtocolException e) { 
            tvJson.setText("protocol error"); 
            e.printStackTrace(); 
        } catch (IOException e) { 
            tvJson.setText("IO error"); 
            e.printStackTrace(); 
        
        return strResult; 
    
    // 普通Json数据解析 
    private void parseJson(String strResult) { 
        try
            JSONObject jsonObj = new JSONObject(strResult).getJSONObject("singer"); 
            int id = jsonObj.getInt("id"); 
            String name = jsonObj.getString("name"); 
            String gender = jsonObj.getString("gender"); 
            tvJson.setText("ID号"+id + ", 姓名:" + name + ",性别:" + gender); 
        } catch (JSONException e) { 
            System.out.println("Json parse error"); 
            e.printStackTrace(); 
        
    
    //解析多个数据的Json
    private void parseJsonMulti(String strResult) { 
        try
            JSONArray jsonObjs = new JSONObject(strResult).getJSONArray("singers"); 
            String s = ""
            for(int i = 0; i < jsonObjs.length() ; i++){ 
                JSONObject jsonObj = ((JSONObject)jsonObjs.opt(i)) 
                .getJSONObject("singer"); 
                int id = jsonObj.getInt("id"); 
                String name = jsonObj.getString("name"); 
                String gender = jsonObj.getString("gender"); 
                s +=  "ID号"+id + ", 姓名:" + name + ",性别:" + gender+ "\n"
            
            tvJson.setText(s); 
        } catch (JSONException e) { 
            System.out.println("Jsons parse error !"); 
            e.printStackTrace(); 
        
    

jsonObject jsonArray jsonTokener jsonStringer,json解析以及http请求获取josn数据并加以解析的更多相关文章

  1. [JSONObject/JSONArray] - 定制的JSON格式返回

    当前开发的程序中.因为抛弃了jsp的渲染,改为thymeleaf,并在比较厉害的前端进行数据json的渲染无误后,得出此json数据返回. 以往的Map<String,Object>返回j ...

  2. python解析发往本机的数据包示例 (解析数据包)

    tcp.py # -*- coding: cp936 -*- import socket from struct import * from time import ctime,sleep from ...

  3. 关于 C# DataSet.ReadXml 无法获取Xml数据的问题解析

    首先这次遇到问题的是,C# Winform 项目中新建的数据集 IDE 是 VS2013 调用如下: private void Form1_Load(object sender, EventArgs ...

  4. android通过httpClient请求获取JSON数据并且解析

    使用.net创建一个ashx文件,并response.write  json格式 public void ProcessRequest(HttpContext context) { context.R ...

  5. java 字符串解析为json 使用org.json包的JSONObject+JSONArray

    参考: https://blog.csdn.net/xingfei_work/article/details/76572550 java中四种json解析方式 JSONObject+JSONArray ...

  6. Android-json解析:原生JSONObject+JSONArray的使用【转】

    原文地址:https://blog.csdn.net/sinat_31057219/article/details/71518123 一.JSONObject和JSONArray的数据表示形式 JSO ...

  7. 011-JSON、JSONObject、JSONArray使用、JSON数组形式字符串转换为List<Map<String,String>>的8种方法

    一.JSON数据格式 1.1.常用JSON数据格式 1.对象方式:JSONObject的数据是用 { } 来表示的, 例如: { "id" : "123", & ...

  8. JSONObject JSONArray json字符串 HashMap ArryList 在java开发中用到的数据结构

    1.JSONObject  长成这样的:   { "key1":value1, "key2":value2, "key3":value3} ...

  9. [转]json+JSONObject+JSONArray 结合使用

    JSONObject与JSONArray的区别简述: 区别在于JSONObject是一个{}包裹起来的一个对象(Object),而JSONArray则是[]包裹起来的一个数组(Array),说白点就是 ...

随机推荐

  1. phalcon: crypt-encrypt/decrypt用法

    phalcon:crypt加密与解密 可以在入口文件index.php进行配置,也可以不配置: $di->set('crypt', function(){ $crypt = new \Phalc ...

  2. XML Attributes(XML属性)

    XML Attributes(XML属性) android:autoLink  是否自动链接网址或邮箱地址: android:autoText  自动检测错误: android:bufferType  ...

  3. mac 下基于firebreath 开发多浏览器支持的浏览器插件

    mac 下基于firebreath 开发多浏览器支持的浏览器插件 首先要区分什么是浏览器扩展和浏览器插件;插件可以像本地程序一样做的更多 一. 关于 firebreath http://www.fir ...

  4. vc++编译libtiff4.0.4

    目录 第1章简介    1 第2章命令行编译    2 2.1 编译    2 2.1.1 使用VC++2010编译    2 2.1.2 使用VC++6编译    4 2.2 生成的文件    5 ...

  5. MySQL中基本的多表连接查询教程

    一.多表连接类型1. 笛卡尔积(交叉连接) 在MySQL中可以为CROSS JOIN或者省略CROSS即JOIN,或者使用','  如: SELECT * FROM table1 CROSS JOIN ...

  6. Android 反编译apk 详解

    测试环境: win 7 使用工具: CSDN上下载地址: apktool (资源文件获取)  下载          dex2jar(源码文件获取) 下载        jd-gui  (源码查看)  ...

  7. 高性能Web服务端 PHP vs Node.js vs Nginx-Lua 的对比分析

    1. ngx_lua nodejs php 比较 我在研究一阵子ngx_lua之后发现lua语法和js真的很像,同时ngx_lua模型也是单线程的异步的事件驱动的,工作原理和nodejs相同,代码甚至 ...

  8. Scala学习之: Hello Word!

    scala 是一门纯粹的面向对象的语言 , 结合了python和java的优点. 它和java的集合度很高,是一个在JVM上运行的非java语言(PS 其实scala也是用java编写的) 安装sca ...

  9. 《Play for Java》学习笔记(四)Controller

    play的一大优势是可以将HTTP映射到JAVA API代码(Type-safe mapping from HTTP to an idiomatic Scala or Java API),完美的实现了 ...

  10. Axis2 webservice入门--开发环境搭建,概念理解

    关于webservice的概念,网上有各种解释,但是不太好懂. 可以这样理解:1.一个webservice就是一个“功能”,只是这个功能是别人写好的,被放在别人的网站上.                ...