91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JDK反序列化時修改類全限定性名的示例分析

發布時間:2021-07-23 09:17:55 來源:億速云 閱讀:127 作者:小新 欄目:編程語言

小編給大家分享一下JDK反序列化時修改類全限定性名的示例分析,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!

應用場景

SpringSecurityOAuth3有一個奇葩的設計,那就是它將與access_token相關的所有屬于都封裝到OAuth3AccessToken中,然后保存時會直接將該對象序列化成字節寫入數據庫。我們在資源服務器中想要直接讀數據庫來取出access_token來驗證令牌的有效性,然而又不想引入SpringSecurity的相關依賴污染jar包。這時可以將SpringSecurity中OAuth3AccessToken的唯一實現類DefaultOAuth3AccessToken的源碼copy到我們的項目中,然后通過JDBC讀取byte[],通過JDK自帶的反序列化機制來還原DefaultOAuth3AccessToken對象。這時就會遇到問題,即原來的OAuth3AccessToken所在包是以org.springframework.security開頭的,而我們copy過來源碼后,包名是以我們自己定義的包cn.com.XXXX開頭的,這樣在反序列化時,即使兩個類的字段完全一樣,但由于字節流中存儲的類信息的全限定性名不同,也會導致反序列化失敗。

解決方案

我們可以定義子類繼承JDK的ObjectInputStream,然后重寫readClassDescriptor()方法:

@Override
    protected ObjectStreamClass readClassDescriptor() throws IOException, ClassNotFoundException {
	ObjectStreamClass read = super.readClassDescriptor();
	if (read.getName().startsWith("原包名")) {
		Class type = Class.forName(read.getName().replace("新包名"));
		return ObjectStreamClass.lookup(type);
	}
	return read;
}

這樣在反序列化時就不會報錯了。原理并不復雜,其實就是在解析字節流時,將解析后應為org.springframework.security.oauth3.common.DefautOAuthToken的class,替換成了我們自己copy過來源碼的cn.com.XXXXXX.DefaultOAuthToken從而達到”欺騙”的目的。在該場景下,我們就可以做到在資源提供方不引入SpringSecurity框架而只使用SpringSecurityOAuth3的授權服務。資源提供方直接讀數據庫來驗證令牌的有效性,而不是向授權服務查詢。

看完了這篇文章,相信你對“JDK反序列化時修改類全限定性名的示例分析”有了一定的了解,如果想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

jdk
AI

淅川县| 瓮安县| 漯河市| 纳雍县| 景洪市| 梅河口市| 日照市| 正蓝旗| 通河县| 丰顺县| 互助| 泸西县| 余江县| 延安市| 辽中县| 衡阳市| 岳阳市| 彭州市| 张掖市| 五峰| 布尔津县| 西贡区| 汨罗市| 海阳市| 乌拉特前旗| 安庆市| 乐东| 翁源县| 辽中县| 武安市| 遵义市| 双牌县| 陈巴尔虎旗| 阿拉善右旗| 佛坪县| 绍兴县| 阆中市| 云林县| 阿城市| 望城县| 贵州省|