国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術(shù)文章
文章詳情頁

Spring Security如何基于Authentication獲取用戶信息

瀏覽:81日期:2023-09-13 15:35:24

Spring Security使用一個(gè)Authentication對象來描述當(dāng)前用戶的相關(guān)信息。SecurityContextHolder中持有的是當(dāng)前用戶的SecurityContext,而SecurityContext持有的是代表當(dāng)前用戶相關(guān)信息的Authentication的引用。

這個(gè)Authentication對象不需要我們自己去創(chuàng)建,在與系統(tǒng)交互的過程中,Spring Security會(huì)自動(dòng)為我們創(chuàng)建相應(yīng)的Authentication對象,然后賦值給當(dāng)前的SecurityContext。

但是往往我們需要在程序中獲取當(dāng)前用戶的相關(guān)信息,比如最常見的是獲取當(dāng)前登錄用戶的用戶名。在程序的任何地方,通過如下方式我們可以獲取到當(dāng)前用戶的用戶名。

public String getCurrentUsername() { Object principal = SecurityContextHolder.getContext().getAuthentication().getPrincipal(); if (principal instanceof UserDetails) { return ((UserDetails) principal).getUsername(); } if (principal instanceof Principal) { return ((Principal) principal).getName(); } return String.valueOf(principal); }

通過Authentication.getPrincipal()可以獲取到代表當(dāng)前用戶的信息,這個(gè)對象通常是UserDetails的實(shí)例。獲取當(dāng)前用戶的用戶名是一種比較常見的需求,關(guān)于上述代碼其實(shí)Spring Security在Authentication中的實(shí)現(xiàn)類中已經(jīng)為我們做了相關(guān)實(shí)現(xiàn),所以獲取當(dāng)前用戶的用戶名最簡單的方式應(yīng)當(dāng)如下。

public String getCurrentUsername() { return SecurityContextHolder.getContext().getAuthentication().getName(); }

此外,調(diào)用SecurityContextHolder.getContext()獲取SecurityContext時(shí),如果對應(yīng)的SecurityContext不存在,則Spring Security將為我們建立一個(gè)空的SecurityContext并進(jìn)行返回。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Spring
相關(guān)文章:
主站蜘蛛池模板: 苍梧县| 余江县| 确山县| 衡南县| 外汇| 锦州市| 揭东县| 成安县| 谢通门县| 德清县| 皋兰县| 石嘴山市| 抚顺县| 南涧| 旬阳县| 宁蒗| 阳高县| 汉川市| 东台市| 胶州市| 开鲁县| 长顺县| 司法| 剑阁县| 高陵县| 遵义市| 公主岭市| 苗栗县| 老河口市| 高淳县| 福州市| 安达市| 合阳县| 左贡县| 梁河县| 正安县| 江都市| 海阳市| 德昌县| 兴山县| 桂林市|