本文目錄一覽:
- 1、怎樣使用Gson 解析 json字符串
- 2、如何用Gson解析複雜的Json數據
- 3、如何用gson解析jsonarray
- 4、java怎麼使用gson解析json字符串
- 5、Android Gson 使用詳解
怎樣使用Gson 解析 json字符串
步驟1:目標:將從webservice傳回的json
1
{
“status”: 0,
“result”: {
“location”: {
“lng”: 103.98964143811,
“lat”: 30.586643130352
},
“formatted_address”: “四川省成都市雙流縣北一街154”,
“business”: “簇橋,金花橋”,
“addressComponent”: {
“city”: “成都市”,
“district”: “雙流縣”,
“province”: “四川省”,
“street”: “北一街”,
“street_number”: “154”
},
“cityCode”: 75
}
}
2
先普及下json數據格式定義: json數據只有兩種格式.
一種是對象: 一個大括號包裹的內容就是一個對象.裡面是無數個逗號相間隔的鍵值對
{ “firstName”: “Brett”, “lastName”:”McLaughlin”, “email”: “aaaa” }
一種是數組:一個方括號包裹的內容就是一個數組,裡面是無數個逗號相間隔的json對象
如:
{
“people”: [
{
“firstName”: “Brett”,
“lastName”: “McLaughlin”,
“email”: “aaaa”
},
{
“firstName”: “Jason”,
“lastName”: “Hunter”,
“email”: “bbbb”
},
{
“firstName”: “Elliotte”,
“lastName”: “Harold”,
“email”: “cccc”
}
]
}
END
步驟2 定義json數據格式對應的javaBean
1
public class Result {
private Integer status;
private ResultDetail result;
public Result() {
}
public Result(Integer status, ResultDetail result) {
super();
this.status = status;
this.result = result;
}
public ResultDetail getResult() {
return this.result;
}
public Integer getStatus() {
return this.status;
}
public void setResult( ResultDetail result ) {
this.result = result;
}
public void setStatus( Integer status ) {
this.status = status;
}
@Override
public String toString() {
return “Result [status=” + this.status + “, result=” + this.result
+ “]”;
}
}
2
public class ResultDetail {
Location location;
String formatted_address;
AddressComponent addressComponent;
String business;
String cityCode;
public ResultDetail() {
super();
// TODO Auto-generated constructor stub
}
public ResultDetail(Location location, String formatted_address,
AddressComponent addressComponent, String business, String cityCode) {
super();
this.location = location;
this.formatted_address = formatted_address;
this.addressComponent = addressComponent;
this.business = business;
this.cityCode = cityCode;
}
public AddressComponent getAddressComponent() {
return this.addressComponent;
}
public String getBusiness() {
return this.business;
}
public String getCityCode() {
return this.cityCode;
}
public String getFormatted_address() {
return this.formatted_address;
}
public Location getLocation() {
return this.location;
}
public void setAddressComponent( AddressComponent addressComponent ) {
this.addressComponent = addressComponent;
}
public void setBusiness( String business ) {
this.business = business;
}
public void setCityCode( String cityCode ) {
this.cityCode = cityCode;
}
public void setFormatted_address( String formatted_address ) {
this.formatted_address = formatted_address;
}
public void setLocation( Location location ) {
this.location = location;
}
}
3
public class Location {
String lng;
String lat;
public Location() {
}
public Location(String lng, String lat) {
this.lng = lng;
this.lat = lat;
}
public String getLat() {
return this.lat;
}
public String getLng() {
return this.lng;
}
public void setLat( String lat ) {
this.lat = lat;
}
public void setLng( String lng ) {
this.lng = lng;
}
@Override
public String toString() {
return “Location [lng=” + this.lng + “, lat=” + this.lat + “]”;
}
}
4
public class AddressComponent {
String city;
String district;
String province;
String street;
String street_number;
public AddressComponent() {
super();
// TODO Auto-generated constructor stub
}
public AddressComponent(String city, String district, String province,
String street, String street_number) {
super();
this.city = city;
this.district = district;
this.province = province;
this.street = street;
this.street_number = street_number;
}
public String getCity() {
return this.city;
}
public String getDistrict() {
return this.district;
}
public String getProvince() {
return this.province;
}
public String getStreet() {
return this.street;
}
public String getStreet_number() {
return this.street_number;
}
public void setCity( String city ) {
this.city = city;
}
public void setDistrict( String district ) {
this.district = district;
}
public void setProvince( String province ) {
this.province = province;
}
public void setStreet( String street ) {
this.street = street;
}
public void setStreet_number( String street_number ) {
this.street_number = street_number;
}
@Override
public String toString() {
return “AddressComponent [city=” + this.city + “, district=”
+ this.district + “, province=” + this.province + “, street=”
+ this.street + “, street_number=” + this.street_number + “]”;
}
}
5
測試:
jsonString ( 目標json數據,已經在最上面寫好的)
System.out.println( “jsonString:” + jsonString );
Gson gson = new Gson();
Result fromJson = gson.fromJson( jsonString.toString() ,
Result.class );
System.out.println( “******************************************” );
System.out.println( fromJson );
6
結果:
jsonString:
{“status”:0,”result”:{“location”:
{“lng”:103.98964143811,”lat”:30.586643130352},”formatted_address”:”四川省成都
市雙流縣北一街154″,”business”:”簇橋,金花橋”,”addressComponent”:{“city”:”成都
市”,”district”:”雙流縣”,”province”:”四川省”,”street”:”北一
街”,”street_number”:”154″},”cityCode”:75}}
*******************************************
Result
[status=0, result=ResultDetail [location=Location [lng=103.98964143811,
lat=30.586643130352], formatted_address=四川省成都市雙流縣北一街154,
addressComponent=AddressComponent [city=成都市, district=雙流縣, province=四川省,
street=北一街, street_number=154], business=簇橋,金花橋, cityCode=75]]
7
可見,jsonString已經成功的被轉換成了對應的javaBean
END
步驟3 : 總結.說明
1
Gson可以很輕鬆的實現javaBean和jsonString之間的互轉.只需要明白json如何定義.剩下的就非常簡單了.
2
推薦使用該框架,在網上看到過一篇解析json的各種方式的效率比較. Gsoon的效率是最高的.
3
再推薦一個jsonString格式化工具.那樣能方便你的閱讀-地址可以在參考資料中找到
4
當然上面的例子只是Gson的很小的一個用例,對於將javabean轉換成jsonString,以及更為複雜的使用.請關注我後續經驗
如何用Gson解析複雜的Json數據
你先定義類,然後使用Gson的fromJson方法轉換成類。
下面是我的代碼:
public class showapi_res_body {
private cityInfo cityInfo = new cityInfo();
private f1 f1 = new f1();
@Override
public String toString() {
return “showapi_res_body [cityInfo=” + cityInfo.toString() + “, f1=” + f1.toString() + “]”;
}
}
public class day_weather_pic {
private int night_air_temperature = 19;
private String night_weather = “多雲”;
@Override
public String toString() {
return “day_weather_pic [night_air_temperature=” + night_air_temperature + “, night_weather=” + night_weather
+ “]”;
}
}
public class f1 {
private String day=”20150906″;
private int day_air_temperature=3;
private String day_weather= “晴”;
private day_weather_pic day_weather_pic = new day_weather_pic();
@Override
public String toString() {
return “f1 [day=” + day + “, day_air_temperature=” + day_air_temperature + “, day_weather=” + day_weather
+ “, day_weather_pic=” + day_weather_pic.toString() + “]”;
}
}
public class cityInfo {
private String c2 =”lanzhou”;
private String c3 =”蘭州”;
@Override
public String toString() {
return “cityInfo [c2=” + c2 + “, c3=” + c3 + “]”;
}
}
public class showapi {
private int showapi_res_code = 0;
private String showapi_res_error = “”;
private showapi_res_body showapi_res_body = new showapi_res_body();
@Override
public String toString() {
return “showapi [showapi_res_code=” + showapi_res_code + “, showapi_res_error=” + showapi_res_error
+ “, showapi_res_body=” + showapi_res_body.toString() + “]”;
}
}
public class test {
public static void main(String[] args) {
showapi anObject = new showapi();
Gson gson = new Gson();
String json = gson.toJson(anObject);
System.out.println(json.toString());
showapi a = gson.fromJson(json, showapi.class);
System.out.println(a.toString());
}
}
如何用gson解析jsonarray
Json是一種類似於XML的通用數據交換格式,具有比XML更高的傳輸效率.
從結構上看,所有的數據(data)最終都可以分解成三種類型:
第一種類型是標量(scalar),也就是一個單獨的字符串(string)或數字(numbers),比如”北京”這個單獨的詞。
第二種類型是序列(sequence),也就是若干個相關的數據按照一定順序並列在一起,又叫做數組(array)或列表(List),比如”北京,上海”。
第三種類型是映射(mapping),也就是一個名/值對(Name/value),即數據有一個名稱,還有一個與之相對應的值,這又稱作散列(hash)或字典(dictionary),比如”首都:北京”。
Json的規格非常簡單,只用一個頁面幾百個字就能說清楚,而且Douglas Crockford聲稱這個規格永遠不必升級,因為該規定的都規定了。
1) 並列的數據之間用逗號(”,”)分隔。
2) 映射用冒號(”:”)表示。
3) 並列數據的集合(數組)用方括號(“[]”)表示。
4) 映射的集合(對象)用大括號(”{}”)表示。
在Android中可以使用Gson解析JSON數據
首先,從 code.google.com/p/google-gson/downloads/list下載GsonAPI:
google-gson-1.7.1-release.zip
把gson-1.7.jar copy到libs(項目根目錄新建一個libs文件夾)中。
可以使用以下兩種方法解析JSON數據:
通過獲取JsonReader對象解析JSON數據:
java怎麼使用gson解析json字符串
Gson是谷歌推出的解析json數據以及將對象轉換成json數據的一個開源框架. 現在json因其易讀性和高效率而被廣泛的使用着.
相對於java以及其它json的解析框架,Gson非常的好用.
簡單來講就是根據json的數據結構定義出相應的javabean —“new”出Gson的實例gson—-gson.fromJson(jsonString,JavaBean.class) 即可.
下面給出一個實例來說明.
步驟1:目標:將從webservice傳回的json
{
“status”: 0,
“result”: {
“location”: {
“lng”: 103.98964143811,
“lat”: 30.586643130352
},
“formatted_address”: “四川省成都市雙流縣北一街154”,
“business”: “簇橋,金花橋”,
“addressComponent”: {
“city”: “成都市”,
“district”: “雙流縣”,
“province”: “四川省”,
“street”: “北一街”,
“street_number”: “154”
},
“cityCode”: 75
}
}
先普及下json數據格式定義: json數據只有兩種格式.
一種是對象: 一個大括號包裹的內容就是一個對象.裡面是無數個逗號相間隔的鍵值對
{ “firstName”: “Brett”, “lastName”:”McLaughlin”, “email”: “aaaa” }
一種是數組:一個方括號包裹的內容就是一個數組,裡面是無數個逗號相間隔的json對象
如:
{
“people”: [
{
“firstName”: “Brett”,
“lastName”: “McLaughlin”,
“email”: “aaaa”
},
{
“firstName”: “Jason”,
“lastName”: “Hunter”,
“email”: “bbbb”
},
{
“firstName”: “Elliotte”,
“lastName”: “Harold”,
“email”: “cccc”
}
]
}
步驟2 定義json數據格式對應的javaBean
public class Result {
private Integerstatus;
private ResultDetailresult;
public Result() {
}
public Result(Integer status, ResultDetail result) {
super();
this.status = status;
this.result = result;
}
public ResultDetail getResult() {
return this.result;
}
public Integer getStatus() {
return this.status;
}
public void setResult( ResultDetail result ) {
this.result = result;
}
public void setStatus( Integer status ) {
this.status = status;
}
@Override
public String toString() {
return “Result [status=” + this.status + “, result=” + this.result
+ “]”;
}
}
public class ResultDetail {
Locationlocation;
Stringformatted_address;
AddressComponentaddressComponent;
Stringbusiness;
StringcityCode;
public ResultDetail() {
super();
// TODO Auto-generated constructor stub
}
public ResultDetail(Location location, String formatted_address,
AddressComponent addressComponent, String business, String cityCode) {
super();
this.location = location;
this.formatted_address = formatted_address;
this.addressComponent = addressComponent;
this.business = business;
this.cityCode = cityCode;
}
public AddressComponent getAddressComponent() {
return this.addressComponent;
}
public String getBusiness() {
return this.business;
}
public String getCityCode() {
return this.cityCode;
}
public String getFormatted_address() {
return this.formatted_address;
}
public Location getLocation() {
return this.location;
}
public void setAddressComponent( AddressComponent addressComponent ) {
this.addressComponent = addressComponent;
}
public void setBusiness( String business ) {
this.business = business;
}
public void setCityCode( String cityCode ) {
this.cityCode = cityCode;
}
public void setFormatted_address( String formatted_address ) {
this.formatted_address = formatted_address;
}
public void setLocation( Location location ) {
this.location = location;
}
}
public class Location {
Stringlng;
Stringlat;
public Location() {
}
public Location(String lng, String lat) {
this.lng = lng;
this.lat = lat;
}
public String getLat() {
return this.lat;
}
public String getLng() {
return this.lng;
}
public void setLat( String lat ) {
this.lat = lat;
}
public void setLng( String lng ) {
this.lng = lng;
}
@Override
public String toString() {
return “Location [lng=” + this.lng + “, lat=” + this.lat + “]”;
}
}
public class AddressComponent {
Stringcity;
Stringdistrict;
Stringprovince;
Stringstreet;
Stringstreet_number;
public AddressComponent() {
super();
// TODO Auto-generated constructor stub
}
public AddressComponent(String city, String district, String province,
String street, String street_number) {
super();
this.city = city;
this.district = district;
this.province = province;
this.street = street;
this.street_number = street_number;
}
public String getCity() {
return this.city;
}
public String getDistrict() {
return this.district;
}
public String getProvince() {
return this.province;
}
public String getStreet() {
return this.street;
}
public String getStreet_number() {
return this.street_number;
}
public void setCity( String city ) {
this.city = city;
}
public void setDistrict( String district ) {
this.district = district;
}
public void setProvince( String province ) {
this.province = province;
}
public void setStreet( String street ) {
this.street = street;
}
public void setStreet_number( String street_number ) {
this.street_number = street_number;
}
@Override
public String toString() {
return “AddressComponent [city=” + this.city + “, district=”
+ this.district + “, province=” + this.province + “, street=”
+ this.street + “, street_number=” + this.street_number + “]”;
}
}
測試:
jsonString ( 目標json數據,已經在最上面寫好的)
System.out.println( “jsonString:” + jsonString );
Gson gson = new Gson();
Result fromJson = gson.fromJson( jsonString.toString() ,Result.class );
System.out.println( “******************************************” );
System.out.println( fromJson );
結果:
jsonString:{“status”:0,”result”:{“location”:{“lng”:103.98964143811,”lat”:30.586643130352},”formatted_address”:”四川省成都市雙流縣北一街154″,”business”:”簇橋,金花橋”,”addressComponent”:{“city”:”成都市”,”district”:”雙流縣”,”province”:”四川省”,”street”:”北一街”,”street_number”:”154″},”cityCode”:75}}
*******************************************
Result [status=0, result=ResultDetail [location=Location [lng=103.98964143811, lat=30.586643130352], formatted_address=四川省成都市雙流縣北一街154, addressComponent=AddressComponent [city=成都市, district=雙流縣, province=四川省, street=北一街, street_number=154], business=簇橋,金花橋, cityCode=75]]
可見,jsonString已經成功的被轉換成了對應的javaBean
步驟3 : 總結.說明
Gson可以很輕鬆的實現javaBean和jsonString之間的互轉.只需要明白json如何定義.剩下的就非常簡單了.
Android Gson 使用詳解
Json 是一種文本形式的數據交換格式,比 xml 更為輕量。Json 的解析和生成的方式很多,在 Android 平台上最常用的類庫有 Gson 和 FastJson 兩種,這裡要介紹的是 Gson
Gson 的 GitHub 主頁點擊這裡: Gson
在進行序列化與反序列操作前,需要先實例化一個 com .google.gson.Gson 對象,獲取 Gson 對象的方法有兩種
利用 Gson 可以很方便地生成 Json 字符串,通過使用 addProperty 的四個重載方法
addProperty 方法底層調用的是 add(String property, JsonElement value) 方法,即將基本數據類型轉化為了 JsonElement 對象,JsonElement 是一個抽象類,而 JsonObject 繼承了 JsonElement ,因此我們可以通過 JsonObject 自己來構建一個 JsonElement
Json數組 與 字符串數組
Json數組 與 List
Gson 也提供了 toJson() 和 fromJson() 兩個方法用於轉化 Model 與 Json,前者實現了序列化,後者實現了反序列化
首先,聲明一個 User 類
序列化的方法很簡單,調用 gson 對象的 toJson 方法,傳入要序列化的對象
反序化的方式也類似
繼續使用上一節聲明的 User 類,根據 User 類聲明的各個屬性名,移動端的開發者希望接口返回的數據格式即是如下這樣的
如果沒有和服務器端溝通好或者是 API 改版了,接口返回的數據格式可能是這樣的
如果繼續使用上一節介紹的方法,那無疑會解析出錯
例如
name 屬性值解析不到,所以為 null
此時為了兼顧多種格式的數據,就需要使用 SerializedName 註解
根據 SerializedName 的聲明來看,SerializedName 包含兩個屬性值,一個是字符串,一個是字符串數組,而字符串數組含有默認值
SerializedName 的作用是為了在序列化或反序列化時,指導 Gson 如果將原有的屬性名和其它特殊情況下的屬性名聯繫起來
例如,修改 User 類,為 name 聲明 SerializedName 註解,註解值為 userName
在序列時,Json 格式就會相應改變
在反序列化時也一樣,能夠解析到正確的屬性值
還有個問題沒解決,為了應對多種屬性名不一致的情況,難道我們要聲明多個 User 類嗎?這顯然是不現實的,所以還需要為 User 類設置多個備選屬性名,這就需要用到 SerializedName 註解的另一個屬性值 alternate 了。
以下幾種情況都能夠被正確的反序列化
有時候並不是所有的字段都需要進行系列化和反序列化,因此需要對某些字段進行排除,有四種方法可以來實現這種需求。
Expose 註解包含兩個屬性值,且均聲明了默認值。Expose 的含義即為“暴露”,即用於對外暴露字段,serialize 用於指定是否進行序列化,deserialize 用於指定是否進行反序列化。如果字段不聲明 Expose 註解,則意味着不進行序列化和反序列化操作,相當於兩個屬性值均為 false 。此外,Expose 註解需要和 GsonBuilder 構建的 Gson 對象一起使用才能生效。
Expose 註解的註解值聲明情況有四種
現在來看個例子,修改 User 類
按照如上的註解值,只有聲明了 Expose 註解且 serialize 值為 true 的字段才能被序列化,只有聲明了 Expose 註解且 deserialize 值為 true 的字段才能被反序列化
Gson 提供了 @Since 和 @Until 兩個註解基於版本對字段進行過濾,@Since 和 @Until 都包含一個 Double 屬性值,用於設置版本號。Since 的意思是“自……開始”,Until 的意思是“到……為止”,一樣要和 GsonBuilder 配合使用。
當版本( GsonBuilder 設置的版本) 大於或等於 Since 屬性值或小於 Until 屬性值時字段會進行序列化和反序列化操作,而沒有聲明註解的字段都會加入序列化和反序列操作
現在來看個例子,修改 User 類
訪問修飾符由 java.lang.reflect.Modifier 提供 int 類型的定義,而 GsonBuilder 對象的 excludeFieldsWithModifiers 方法接收一個 int 類型可變參數,指定不進行序列化和反序列化操作的訪問修飾符字段
看個例子
GsonBuilder 類包含 setExclusionStrategies(ExclusionStrategy… strategies) 方法用於傳入不定長參數的策略方法,用於直接排除指定字段名或者指定字段類型
看個例子
字段名為 “intField” 和字段類型為 double 的字段都會被排除掉
setExclusionStrategies 方法在序列化和反序列化時都會生效,如果只是想指定其中一種情況下的排除策略或分別指定排除策略,可以改為使用以下兩個方法
對於 Gson 而言,在序列化時如果某個屬性值為 null 的話,那麼在序列化時該字段不會參與進來,如果想要顯示輸出該字段的話,可以通過 GsonBuilder 進行配置
默認的序列化後的 Josn 字符串並不太直觀,可以選擇格式化輸出
Gson 也可以對時間值進行格式化
TypeAdapter 是一個泛型抽象類,用於接管某種類型的序列化和反序列化過程,包含兩個抽象方法,分別用於自定義序列化和反序列化過程
下面看個簡單的例子
定義 TypeAdapter 的子類 UserTypeAdapter 來接管 User 類的序列化和反序列化過程
這裡設定當 User 類序列化時 Json 中的Key值都是大寫字母開頭,反序列化時支持“name”和“Name”兩種不同的 Json 風格
可以看到 User 類按照預定義的策略來完成序列化和反序列化了
TypeAdapter 將序列化和反序列操作都接管了過來,其實 Gson 還提供了只接管序列化過程的接口,即 JsonSerializer
看個例子
相對應的,JsonDeserializer 接口提供了反序列化的接口
這裡有個比較麻煩的地方,那就是在使用 TypeAdapter 、JsonSerializer 和 JsonDeserializer 時,總需要調用 registerTypeAdapter 方法進行註冊,那有沒有更簡單的註冊方法呢?
有的,Gosn 還提供了另一個註解 @JsonAdapter 用於進行簡單的聲明
類似於這樣,聲明了 User 類的序列化或反序列化操作由 UserTypeAdapter 完成,註解的優先級高於 registerTypeAdapter 方法
TypeAdapterFactory 是用於創建 TypeAdapter 的工廠類,通過參數 TypeToken 來查找確定對應的 TypeAdapter,如果沒有就返回 null 並由 Gson 默認的處理方法來進行序列化和反序列化操作,否則就由用戶預定義的 TypeAdapter 來進行處理
這一篇文章好像寫得太長了一點?Gson 的知識點介紹到這裡也差不多了,以後如果還發現新內容的話我會繼續補充,現在就先這樣啦
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/206238.html