序列化的幾種方式

什么是序列化尊残?

內(nèi)存中的數(shù)據(jù)對(duì)象只有轉(zhuǎn)換為二進(jìn)制流才可以進(jìn)行數(shù)據(jù)持久化和網(wǎng)絡(luò)傳輸炒瘸。將數(shù)據(jù)對(duì)象轉(zhuǎn)換為二進(jìn)制流的過(guò)程稱為對(duì)象的序列化(Serialization)。反之夜郁,將二進(jìn)制流恢復(fù)為數(shù)據(jù)對(duì)象的過(guò)程稱為反序列化(Deserialization)什燕。序列化需要保留充分的信息以恢復(fù)數(shù)據(jù)對(duì)象,但是為了節(jié)約存儲(chǔ)空間和網(wǎng)絡(luò)帶寬竞端,序列化后的二進(jìn)制流又要盡可能小屎即。序列化常見(jiàn)的使用場(chǎng)景是RPC框架的數(shù)據(jù)傳輸。常見(jiàn)的序列化方式有三種:

1.Java原生序列化

Java類通過(guò)實(shí)現(xiàn)Serializable接口來(lái)實(shí)現(xiàn)該類對(duì)象的序列化事富,這個(gè)接口非常特殊技俐,沒(méi)有任何方法,只起標(biāo)識(shí)作用.Java序列化保留了對(duì)象類的元數(shù)據(jù)(如類统台、成員變量雕擂、繼承類信息等),以及對(duì)象數(shù)據(jù)等贱勃,兼容性最好井赌,但不支持跨語(yǔ)言,而且性能一般贵扰。

實(shí)現(xiàn)Serializable接口的類建議設(shè)置serialVersionUID字段值仇穗,如果不設(shè)置,那么每次運(yùn)行時(shí)戚绕,編譯器會(huì)根據(jù)類的內(nèi)部實(shí)現(xiàn)纹坐,包括類名、接口名舞丛、方法和屬性等來(lái)自動(dòng)生成serialVersionUID耘子。如果類的源代碼有修改,那么重新編譯后serial VersionUID的取值可能會(huì)發(fā)生變化球切。因此實(shí)現(xiàn)Serializable接口的類一定要顯式地定義serialVersionUID屬性值谷誓。修改類時(shí)需要根據(jù)兼容性決定是否修改serialVersionUID值:
1.如果是兼容升級(jí),請(qǐng)不要修改serialVersionUID字段吨凑,避免反序列化失敗片林。

2.如果是不兼容升級(jí),需要修改serialVersionUID值怀骤,避免反序列化混亂。

使用Java原生序列化需注意焕妙,Java反序列化時(shí)不會(huì)調(diào)用類的無(wú)參構(gòu)造方法蒋伦,而是調(diào)用native方法將成員變量賦值為對(duì)應(yīng)類型的初始值》偃担基于性能及兼容性考慮痕届,不推薦使用Java 原生序列化韧献。


Java原生序列化

2.Hessian 序列化

Hessian 序列化是一種支持動(dòng)態(tài)類型、跨語(yǔ)言研叫、基于對(duì)象
傳輸?shù)木W(wǎng)絡(luò)協(xié)議锤窑。 Java 對(duì)象序列化的二進(jìn)制流可以被其他語(yǔ)言 ( 如 C++、 Python )反
序列化嚷炉。 Hessian 協(xié)議具有如下特性.
自描述序列化類型渊啰。不依賴外部描述文件或接口定義 , 用一個(gè)字節(jié)表示常用
基礎(chǔ)類型 申屹, 極大縮短二進(jìn)制流绘证。
· 語(yǔ)言無(wú)關(guān),支持腳本語(yǔ)言哗讥。
· 協(xié)議簡(jiǎn)單嚷那,比 Java 原生序列化高效。
相比 Hessian 1.0, Hessian 2.0 中增加了壓縮編碼杆煞,其序列化二進(jìn)制流大小是 Java
序列化的 50% 魏宽, 序列化耗時(shí)是 Java 序列化的 30% ,反序列化耗時(shí)是 Java 反序列化的
20% 决乎。
Hessian 會(huì)把復(fù)雜對(duì)象所有屬性存儲(chǔ)在一個(gè) Map 申 進(jìn)行序列化队询。所以在父類、子
類存在同名成員變量的情況下瑞驱, Hessian 序列化時(shí)娘摔,先序列化子類 ,然后序列化父類唤反,
因此反序列化結(jié)果會(huì)導(dǎo)致子類同名成員變量被父類的值覆蓋凳寺。


阿里首選的序列化方式

3.Json序列化

JSON ( JavaScript O同ect Notation )是一種輕量級(jí)的數(shù)據(jù)交
換格式。 JSON 序列化就是將數(shù)據(jù)對(duì)象轉(zhuǎn)換為 JSON 字符串彤侍。在序列化過(guò)程中拋棄了
類型信息肠缨,所以反序列化時(shí)只有提供類型信息才能準(zhǔn)確地反序列化。相比前兩種方式盏阶,
JSON 可讀性比較好晒奕,方便調(diào)試。
序列化通常會(huì)通過(guò)網(wǎng)絡(luò)傳輸對(duì)象 名斟, 而對(duì)象中往往有敏感數(shù)據(jù)脑慧,所以序列化常常
成為黑客的攻擊點(diǎn),攻擊者巧妙地利用反序列化過(guò)程構(gòu)造惡意代碼砰盐,使得程序在反序
列化的過(guò)程中執(zhí)行任意代碼闷袒。 Java 工程中廣泛使用的 Apache Commons Collections 、
Jackson 岩梳、 fastjson 等都出現(xiàn)過(guò)反序列化漏洞囊骤。如何防范這種黑客攻擊呢晃择?有些對(duì)象的
敏感屬性不需要進(jìn)行序列化傳輸 ,可以加 transient 關(guān)鍵字也物,避免把此屬性信息轉(zhuǎn)化為
序列化的二進(jìn)制流宫屠。如果一定要傳遞對(duì)象的敏感屬性,可以使用對(duì)稱與非對(duì)稱加密方
式獨(dú)立傳輸滑蚯,再使用某個(gè)方法把屬性還原到對(duì)象中浪蹂。應(yīng)用開(kāi)發(fā)者對(duì)序列化要有一定的
安全防范意識(shí) , 對(duì)傳入數(shù)據(jù)的內(nèi)容進(jìn)行校驗(yàn)或權(quán)限控制膘魄,及時(shí)更新安全漏洞乌逐,避免受
到攻擊。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末创葡,一起剝皮案震驚了整個(gè)濱河市浙踢,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌灿渴,老刑警劉巖洛波,帶你破解...
    沈念sama閱讀 206,126評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異骚露,居然都是意外死亡蹬挤,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,254評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門(mén)棘幸,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)焰扳,“玉大人,你說(shuō)我怎么就攤上這事误续《趾罚” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 152,445評(píng)論 0 341
  • 文/不壞的土叔 我叫張陵蹋嵌,是天一觀的道長(zhǎng)育瓜。 經(jīng)常有香客問(wèn)我,道長(zhǎng)栽烂,這世上最難降的妖魔是什么躏仇? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,185評(píng)論 1 278
  • 正文 為了忘掉前任,我火速辦了婚禮腺办,結(jié)果婚禮上焰手,老公的妹妹穿的比我還像新娘。我一直安慰自己怀喉,他們只是感情好册倒,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,178評(píng)論 5 371
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著磺送,像睡著了一般驻子。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上估灿,一...
    開(kāi)封第一講書(shū)人閱讀 48,970評(píng)論 1 284
  • 那天崇呵,我揣著相機(jī)與錄音,去河邊找鬼馅袁。 笑死域慷,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的汗销。 我是一名探鬼主播犹褒,決...
    沈念sama閱讀 38,276評(píng)論 3 399
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼弛针!你這毒婦竟也來(lái)了叠骑?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 36,927評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤削茁,失蹤者是張志新(化名)和其女友劉穎宙枷,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體茧跋,經(jīng)...
    沈念sama閱讀 43,400評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡慰丛,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,883評(píng)論 2 323
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了瘾杭。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片诅病。...
    茶點(diǎn)故事閱讀 37,997評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖粥烁,靈堂內(nèi)的尸體忽然破棺而出贤笆,到底是詐尸還是另有隱情,我是刑警寧澤页徐,帶...
    沈念sama閱讀 33,646評(píng)論 4 322
  • 正文 年R本政府宣布苏潜,位于F島的核電站,受9級(jí)特大地震影響变勇,放射性物質(zhì)發(fā)生泄漏恤左。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,213評(píng)論 3 307
  • 文/蒙蒙 一搀绣、第九天 我趴在偏房一處隱蔽的房頂上張望飞袋。 院中可真熱鬧,春花似錦链患、人聲如沸巧鸭。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,204評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)纲仍。三九已至呀袱,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間郑叠,已是汗流浹背夜赵。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,423評(píng)論 1 260
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留乡革,地道東北人寇僧。 一個(gè)月前我還...
    沈念sama閱讀 45,423評(píng)論 2 352
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像沸版,于是被迫代替她去往敵國(guó)和親嘁傀。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,722評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容