androidjson序列化
⑴ android使用gson解析嵌套復雜的json數據,數據怎麼顯示到布局上,布局怎麼寫
首先先講一個比較簡單點的例子(最簡單的我就不講啦,網上很多),幫助新手理解Gson的使用方法:
比如我們要解析一個下面這種的Json:
String json = {"a":"100","b":[{"b1":"b_value1","b2":"b_value2"},{"b1":"b_value1","b2":"b_value2"}],"c":{"c1":"c_value1","c2":"c_value2"}}
首先我們需要定義一個序列化的Bean,這里採用內部類的形式,看起來會比較清晰一些:
public class JsonBean {
public String a;
public List<B> b;
public C c;
public static class B {
public String b1;
public String b2;
}
public static class C {
public String c1;
public String c2;
}
}
很多時候大家都是不知道這個Bean是該怎麼定義,這裡面需要注意幾點:
1、內部嵌套的類必須是static的,要不然解析會出錯;
2、類裡面的屬性名必須跟Json欄位裡面的Key是一模一樣的;
3、內部嵌套的用[]括起來的部分是一個List,所以定義為 public List<B> b,而只用{}嵌套的就定義為 public C c,
具體的大家對照Json字元串看看就明白了,不明白的我們可以互相交流,本人也是開發新手!
Gson gson = new Gson();
java.lang.reflect.Type type = new TypeToken<JsonBean>() {}.getType();
JsonBean jsonBean = gson.fromJson(json, type);
然後想拿數據就很簡單啦,直接在jsonBean裡面取就可以了!
如果需要解析的Json嵌套了很多層,同樣可以可以定義一個嵌套很多層內部類的Bean,需要細心的對照Json欄位來定義哦。
⑵ 如何:對 JSON 數據進行序列化和反序列化
主要用於存儲對象狀態為另一種通用格式,比如存儲為二進制、xml、json等等,把對象轉換成這種格式就叫序列化,而反序列化通常是從這種格式轉換回來。 使用序列化主要是因為跨平台和對象存儲的需求,因為網路上只允許字元串或者二進制格式,而文...
⑶ 如何在android中使用jackson做json序列化和反序列化
T data = null;
try {
ObjectMapper mapper = new ObjectMapper();
mapper.configure(DeserializationConfig.Feature.FAIL_ON_UNKNOWN_PROPERTIES, false);
data = mapper.readValue(jsonString, type);
} catch (IOException e) {
e.printStackTrace();
}
return data;
}
//對象轉為json字元串
public static String objectToJson(Object object) {
ObjectMapper m = new ObjectMapper();
m.configure(SerializationConfig.Feature.WRITE_NULL_PROPERTIES, false);
ObjectWriter ow = m.writer().withDefaultPrettyPrinter();
String message = "";
try {
message = ow.writeValueAsString(object);
} catch (IOException e) {
⑷ json序列化
php"><?php
$str="_.gm['3006078']=['12-03<br>06:15p<br><fontcolor=red>RunningBall</font>','哥倫比亞甲組聯賽-附加賽','71444','71443','小巴蘭哈拉','卡利阿美利加','H'];
_.gm['3014642']=['12-03<br>07:00p<br><fontcolor=red>RunningBall</font>','墨西哥乙組聯賽乙級-附加賽','73606','73605','可約特斯','亞瑪坎','H'];
_.gm['3011132']=['12-03<br>07:00p<br><fontcolor=red>RunningBall</font>','阿根廷聯邦聯賽A','72908','72907','道格拉斯海格','斯伯迪沃貝爾格拉諾','H'];
_.gm['3011136']=['12-03<br>07:00p<br><fontcolor=red>RunningBall</font>','阿根廷聯邦聯賽A','72914','72913','拉斯佩瑞加斯','尤尼昂桑察勒斯','H'];";
$reg="/_.gm[['"s]+(d+)[s"']]+[['"s=]+([d-]+<br>[d:a-zA-Z]+)<br><font[^>]*>((?:(?!</font>)[sS])+)</font>[,'"s]+([^'",]+)[,'"s]+([^'",]+)[,'"s]+([^'",]+)[,'"s]+([^'",]+)[,'"s]+([^'",]+)[^]]+]/i";
preg_match_all($reg,$str,$mat);
$arr=array('有用信息id','時間','RB','名稱','主隊id','客隊id','主隊名稱','客隊名稱');
for($j=0;$j<count($mat[0]);$j++){
for($i=1;$i<count($mat);$i++){
$tmp=$mat[$i][$j];
$tmp=preg_replace('/<br>/i','',$tmp);
echo($arr[$i-1].':'.$tmp." ");
}
echo("=============================== ");
}
?>
⑸ JSON序列化問題
建立實體類,直接將json字元串序列化成對象,不需要二次序列化,
{"funcname":"add","args":{"a":19,"b":"1","c":""}}
haojson點com/json2csharp/這個可以將json字元串生成對應實體類
⑹ JSON 序列化和反序列化是什麼意思
序列化主要就是為了傳輸方便,將要傳輸的對象序列化為二進制的數據流,效率極高,接收時通過反序列化轉化成對象,從而達到一個傳輸的效果
⑺ android 如何用json傳遞文件
先發現json可以直接傳遞個Object對象。開始時打算將文件讀取成byte[]數組,然後再將byte轉換為object來傳遞。通過如下方法[*]public Object toObject (byte[] bytes) { [*] Object obj = null; [*] try { [*] ByteArrayInputStream bis = new ByteArrayInputStream (bytes); [*] ObjectInputStream ois = new ObjectInputStream (bis); [*] obj = ois.readObject(); [*] ois.close(); [*] bis.close(); [*] } catch (IOException ex) { [*] ex.printStackTrace(); [*] } catch (ClassNotFoundException ex) { [*] ex.printStackTrace(); [*] } [*] return obj; [*] } 但測試發現調用這個函數時發生錯誤java.io.StreamCorruptedException,不知道為什麼。而後又想能不能直接傳遞個File對象,例如:File file = new File(xxx);jsObj.put("key", file);File file2 = jsObj.get("key");請問這樣這樣能不能行通?因為發現很多跨進程傳遞對象數據都必須要求對象是序列化的。所以此處很疑惑通過json方法是否也需要這個File對象要序列化什麼的。
⑻ 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 的知識點介紹到這里也差不多了,以後如果還發現新內容的話我會繼續補充,現在就先這樣啦
⑼ Android開發中為什麼很少使用JSON存儲數據
是可以用JSON存儲數據對象的,而且也是Google推薦的,可以取代以實現Serializable來存儲對象的方法。下面是使用JSON存儲數據的原因。
Android開發中,涉及到對象存儲,通常的做法是直接實現`Serializable`。有關這個介面,它保證了實現該介面的類的對象能夠被`ObjectOutput/InputStream`直接輸入輸出,即序列化。這很方便,但是也很不好。
提到『序列化』,大多數人都想到`Serializable`,而實際上『序列化』的只是指「將對象的狀態信息轉換為可以存儲或傳輸的形式的過程」,Java的`Serializabe`是位元組序列化的一種。
`Serialziable`的缺點之一是,實現了該介面的類將失去靈活性。這一點《Effective Java》第74條也指出了,實現了這個`Serializable`的類將會依賴這個類的內部演化,根源在於UID(Serial version UID)。如果你沒有指定UID,那麼每次這個類被序列化時都會根據這個類的當前狀態生成一個UID。想像這么一種場景:這個類已經被導出了,比如發給其他公司或部門使用了,然後你又修改了這個類,那麼當你再將這個類發布時,由於UID不同,其他公司或部門的程序員將可能得到一個「InvalidClassException」。
這種情況的根本原因是因為你不能控制序列化的實現,你控制不了UID的生成過程。這就需要一個自定義的序列化形式。在Android中,Google推薦JSON序列化。而且Android程序員也可以使用Gson等工具來進行序列化和反序列化。
和`Serializable`的位元組序列化不同,JSON序列化是字元序列化。
此外,`Serializable`只適合存儲對象。由於在傳輸時`Serializalbe`要做大量IO,Android提供了`Parcelable`。
最後,題主不應該把資料庫和JSON,XML比較,如果要比,也只能把資料庫和文件存儲比。資料庫適合存儲數量大,關系復雜的數據,這樣管理,查閱就很方便。與此相對文件存儲適合數量小,關系簡單的數據。
⑽ 怎麼json序列化出來,不是用引用,直接序列化具體的值
eturn Newtonsoft.Json.JsonConvert.SerializeObject(testSchme); 序列化的時候便報這個錯。但是當我把該對象的其中一個集合屬性賦值為null的時候,就可以序列化了。 testS