android 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解析類
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");
- 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);
- }
getType和optType api的使用
getType可以將要獲取的鍵的值轉換為指定的型別,如果無法轉換或沒有值則丟擲JSONException程式碼
optType也是將要獲取的鍵的值轉換為指定的型別,無法轉換或沒有值時返回使用者提供或這預設提供的值
- try {
- // 所有使用的物件都是用上面建立的物件
- // 將第一個電話號碼轉換為數值和將名字轉換為數值
- phone.getLong(0);
- person.getLong("name"); // 會拋異常,因為名字無法轉換為long
- phone.optLong(0); // 程式碼內建的預設值
- phone.optLong(0, 1000); // 使用者提供的預設值
- person.optLong("name");
- person.optLong("name", 1000); // 不像上面那樣拋異常,而是返回1000
- } catch (JSONException ex) {
- // 異常處理程式碼
- }
除了上面的兩個類,還可以使用JSONStringer來構建json文字
Java程式碼
- 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文字解析類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文字中的字元。此時剛開始,即在{處
- jsonParser.next(8); //{ "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");
- jsonParser.next(8); //" : { "c
- // 讀取位置前進到執行字元處(不包括字元)
- jsonParser.skipTo('m');
- jsonParser.next(8); //married"
- } catch (JSONException ex) {
- // 異常處理程式碼
- }
以下是一個標準的JSON請求實現過程:
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解析。
單資料{'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():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/AndroidServ