国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > Java > 正文

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

2024-07-13 10:15:06
字體:
供稿:網(wǎng)友

應(yīng)用場景

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

解決方案

我們可以定義子類繼承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;}

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

總結(jié)

以上就是本文關(guān)于JDK反序列化時修改類的全限定性名解析的全部內(nèi)容,希望對大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站其它相關(guān)專題,如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!


注:相關(guān)教程知識閱讀請移步到JAVA教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 鄢陵县| 通州市| 九江县| 东丽区| 嘉兴市| 开江县| 张家口市| 武平县| 吉木乃县| 江北区| 神农架林区| 潮州市| 仙居县| 封丘县| 侯马市| 海盐县| 灌南县| 安仁县| 乐业县| 长乐市| 平顶山市| 水富县| 广宁县| 景宁| 东乌珠穆沁旗| 日喀则市| 莲花县| 都昌县| 祁门县| 秦安县| 自治县| 彭山县| 霞浦县| 五原县| 松潘县| 鲜城| 弥勒县| 庆城县| 菏泽市| 错那县| 响水县|