首页 > 技术文章 > Json学习

lelouchKOP 2017-04-25 23:19 原文

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文本  
//  {  
//      "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");  
    person.put("age", 100);  
    // 键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); 

JSONString 构造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.value(100);  
      
    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文本解析对象

对于将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) {  
        // 异常处理代码  
    } 

 

 

推荐阅读