Android編程之json解析實例詳解
本文實例分析了Android編程之json解析的方法。分享給大家供大家參考,具體如下:
JSON的定義:
一種輕量級的數(shù)據(jù)交換格式,具有良好的可讀和便于快速編寫的特性。業(yè)內(nèi)主流技術(shù)為其提供了完整的解決方案(有點類似于正則表達式 ,獲得了當(dāng)今大部分語言的支持),從而可以在不同平臺間進行數(shù)據(jù)交換。JSON采用兼容性很高的文本格式,同時也具備類似于C語言體系的行為。 – Json.org
JSON Vs XML
1.JSON和XML的數(shù)據(jù)可讀性基本相同
2.JSON和XML同樣擁有豐富的解析手段
3.JSON相對于XML來講,數(shù)據(jù)的體積小
4.JSON與JavaScript的交互更加方便
5.JSON對數(shù)據(jù)的描述性比XML較差
6.JSON的速度要遠遠快于XML
android2.3提供的json解析類
android的json解析部分都在包org.json下,主要有以下幾個類:
JSONObject:可以看作是一個json對象,這是系統(tǒng)中有關(guān)JSON定義的基本單元,其包含一對兒(Key/Value)數(shù)值。它對外部(External: 應(yīng)用toString()方法輸出的數(shù)值)調(diào)用的響應(yīng)體現(xiàn)為一個標(biāo)準(zhǔn)的字符串(例如:{"JSON": "Hello, World"},最外被大括號包裹,其中的Key和Value被冒號":"分隔)。其對于內(nèi)部(Internal)行為的操作格式略微,例如:初始化一個JSONObject實例,引用內(nèi)部的put()方法添加數(shù)值:new JSONObject().put("JSON", "Hello, World!"),在Key和Value之間是以逗號","分隔。Value的類型包括:Boolean、JSONArray、JSONObject、Number、String或者默認(rèn)值JSONObject.NULL object 。
JSONStringer:json文本構(gòu)建類 ,根據(jù)官方的解釋,這個類可以幫助快速和便捷的創(chuàng)建JSON text。其最大的優(yōu)點在于可以減少由于 格式的錯誤導(dǎo)致程序異常,引用這個類可以自動嚴(yán)格按照J(rèn)SON語法規(guī)則(syntax rules)創(chuàng)建JSON text。每個JSONStringer實體只能對應(yīng)創(chuàng)建一個JSON text。。其最大的優(yōu)點在于可以減少由于格式的錯誤導(dǎo)致程序異常,引用這個類可以自動嚴(yán)格按照J(rèn)SON語法規(guī)則(syntax rules)創(chuàng)建JSON text。每個JSONStringer實體只能對應(yīng)創(chuàng)建一個JSON text。
JSONArray:它代表一組有序的數(shù)值。將其轉(zhuǎn)換為String輸出(toString)所表現(xiàn)的形式是用方括號包裹,數(shù)值以逗號”,”分隔(例如: [value1,value2,value3],大家可以親自利用簡短的代碼更加直觀的了解其格式)。這個類的內(nèi)部同樣具有查詢行為, get()和opt()兩種方法都可以通過index索引返回指定的數(shù)值,put()方法用來添加或者替換數(shù)值。同樣這個類的value類型可以包括:Boolean、JSONArray、JSONObject、Number、String或者默認(rèn)值JSONObject.NULL object。
JSONTokener:json解析類
JSONException:json中用到的異常
JSONObject, JSONArray來構(gòu)建json文本
// 假設(shè)現(xiàn)在要創(chuàng)建這樣一個json文本 // { // "phone" : ["12345678", "87654321"], // 數(shù)組 // "name" : "yuanzhifei89", // 字符串 // "age" : 100, // 數(shù)值 // "address" : { "country" : "china", "province" : "jiangsu" }, // 對象 // "married" : false // 布爾值 // } try { // 首先最外層是{},是創(chuàng)建一個對象 JSONObject person = new JSONObject(); // 第一個鍵phone的值是數(shù)組,所以需要創(chuàng)建數(shù)組對象 JSONArray phone = new JSONArray(); phone.put("12345678").put("87654321"); person.put("phone", phone); person.put("name", "yuanzhifei89"); person.put("age", 100); // 鍵address的值是對象,所以又要創(chuàng)建一個對象 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不支持的數(shù)字格式(NaN, infinities) throw new RuntimeException(ex); }
getType和optType api的使用
getType可以將要獲取的鍵的值轉(zhuǎn)換為指定的類型,如果無法轉(zhuǎn)換或沒有值則拋出JSONException
optType也是將要獲取的鍵的值轉(zhuǎn)換為指定的類型,無法轉(zhuǎn)換或沒有值時返回用戶提供或這默認(rèn)提供的值
try { // 所有使用的對象都是用上面創(chuàng)建的對象 // 將第一個電話號碼轉(zhuǎn)換為數(shù)值和將名字轉(zhuǎn)換為數(shù)值 phone.getLong(0); person.getLong("name"); // 會拋異常,因為名字無法轉(zhuǎn)換為long phone.optLong(0); // 代碼內(nèi)置的默認(rèn)值 phone.optLong(0, 1000); // 用戶提供的默認(rèn)值 person.optLong("name"); person.optLong("name", 1000); // 不像上面那樣拋異常,而是返回1000 } catch (JSONException ex) { // 異常處理代碼 }
除了上面的兩個類,還可以使用JSONStringer來構(gòu)建json文本
try { JSONStringer jsonText = new JSONStringer(); // 首先是{,對象開始。object和endObject必須配對使用 jsonText.object(); jsonText.key("phone"); // 鍵phone的值是數(shù)組。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); // },對象結(jié)束 jsonText.endObject(); } catch (JSONException ex) { throw new RuntimeException(ex); }
json文本解析類JSONTokener
按照RFC4627規(guī)范將json文本解析為相應(yīng)的對象。
對于將json文本解析為對象,只需要用到該類的兩個api:
構(gòu)造函數(shù)
public Object nextValue(); // { // "phone" : ["12345678", "87654321"], // 數(shù)組 // "name" : "yuanzhifei89", // 字符串 // "age" : 100, // 數(shù)值 // "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); // 繼續(xù)向下讀8個json文本中的字符。此時剛開始,即在{處 jsonParser.next(8); //{ "phone。tab算一個字符 // 繼續(xù)向下讀1個json文本中的字符 jsonParser.next(); //" // 繼續(xù)向下讀取一個json文本中的字符。該字符不是空白、同時也不是注視中的字符 jsonParser.nextClean(); //: // 返回當(dāng)前的讀取位置到第一次遇到'a'之間的字符串(不包括a)。 jsonParser.nextString('a'); // ["12345678", "87654321"], "n(前面有兩個空格) // 返回當(dāng)前讀取位置到第一次遇到字符串中(如"0089")任意字符之間的字符串,同時該字符是trimmed的。(此處就是第一次遇到了89) jsonParser.nextTo("0089"); //me" : "yuanzhifei // 讀取位置撤銷一個 jsonParser.back(); jsonParser.next(); //i // 讀取位置前進到指定字符串處(包括字符串) jsonParser.skipPast("address"); jsonParser.next(8); //" : { "c // 讀取位置前進到執(zhí)行字符處(不包括字符) jsonParser.skipTo('m'); jsonParser.next(8); //married" } catch (JSONException ex) { // 異常處理代碼 }
以下是一個標(biāo)準(zhǔn)的JSON請求實現(xiàn)過程:
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); // 發(fā)送請求 HttpResponse httpResponse = new DefaultHttpClient().execute(request); // 得到應(yīng)答的字符串,這也是一個 JSON 格式保存的數(shù)據(jù) String retSrc = EntityUtils.toString(httpResponse.getEntity()); // 生成 JSON 對象 JSONObject result = new JSONObject( retSrc); String token = result.get("token");
下面這個是自己修改別人的小例子,主要是加一些注釋和講解,這個例子主要是使用android進行json解析。
單數(shù)據(jù)
多個數(shù)據(jù)
{"singers":[ {'id':02,'name':'tom','gender':'男'}, {'id':03,'name':'jerry,'gender':'男'}, {'id':04,'name':'jim,'gender':'男'}, {'id':05,'name':'lily,'gender':'女'}]}
下面的類主要是解析單個數(shù)據(jù)parseJson()和多個數(shù)據(jù)的方法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/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) { // 取得返回的數(shù)據(jù) 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數(shù)據(jù)解析 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(); } } //解析多個數(shù)據(jù)的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 = jsonObjs.getJSONObject(i); 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(); } } }
希望本文所述對大家Android程序設(shè)計有所幫助。
- Android中使用Gson解析JSON數(shù)據(jù)的兩種方法
- Android 解析JSON對象及實例說明
- android 解析json數(shù)據(jù)格式的方法
- Android App數(shù)據(jù)格式Json解析方法和常見問題
- Android M(6.x)使用OkHttp包解析和發(fā)送JSON請求的教程
- Android中g(shù)son、jsonobject解析JSON的方法詳解
- Android解析json數(shù)組對象的方法及Apply和數(shù)組的三個技巧
- Android利用Gson解析嵌套多層的Json的簡單方法
- Android json解析及簡單例子
- 探究Android系統(tǒng)中解析JSON數(shù)據(jù)的方式
- 深入淺析Android JSON解析
- Android編程簡單解析JSON格式數(shù)據(jù)的方法示例
相關(guān)文章
Android音頻錄制MediaRecorder之簡易的錄音軟件實現(xiàn)代碼
這篇文章主要介紹了Android音頻錄制MediaRecorder之簡易的錄音軟件實現(xiàn)代碼,有需要的朋友可以參考一下2014-01-01Android開發(fā)手冊TextView屬性實現(xiàn)效果盤點
這篇文章主要為大家介紹了Android開發(fā)手冊TextView屬性實現(xiàn)的效果盤點及使用示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-06-06XListView實現(xiàn)網(wǎng)絡(luò)加載圖片和下拉刷新
這篇文章主要為大家詳細介紹了XListView實現(xiàn)網(wǎng)絡(luò)加載圖片和下拉刷新,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-11-11Android自定義View實現(xiàn)BMI指數(shù)條
這篇文章主要為大家詳細介紹了Android自定義View實現(xiàn)BMI指數(shù)條,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-06-06導(dǎo)入takephoto庫編譯失敗與glide庫沖突應(yīng)排除依賴
今天小編就為大家分享一篇關(guān)于導(dǎo)入takephoto庫編譯失敗與glide庫沖突應(yīng)排除依賴的文章,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2018-10-10Android LocationManager獲取經(jīng)度與緯度等地理信息
這篇文章主要介紹了Android LocationManager獲取經(jīng)度與緯度等地理信息的相關(guān)資料,希望通過本站大家能掌握這樣的知識,需要的朋友可以參考下2017-09-09