色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

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

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

Spring Security使用一個Authentication對象來描述當前用戶的相關信息。SecurityContextHolder中持有的是當前用戶的SecurityContext,而SecurityContext持有的是代表當前用戶相關信息的Authentication的引用。

這個Authentication對象不需要我們自己去創建,在與系統交互的過程中,Spring Security會自動為我們創建相應的Authentication對象,然后賦值給當前的SecurityContext。

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

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()可以獲取到代表當前用戶的信息,這個對象通常是UserDetails的實例。獲取當前用戶的用戶名是一種比較常見的需求,關于上述代碼其實Spring Security在Authentication中的實現類中已經為我們做了相關實現,所以獲取當前用戶的用戶名最簡單的方式應當如下。

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

此外,調用SecurityContextHolder.getContext()獲取SecurityContext時,如果對應的SecurityContext不存在,則Spring Security將為我們建立一個空的SecurityContext并進行返回。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Spring
相關文章:
主站蜘蛛池模板: 成年男女男精品免费视频网站 | 精品日本亚洲一区二区三区 | 韩国美女毛片 | 久久综合狠狠综合狠狠 | 久久99精品久久久久久久野外 | 一级做a爱片久久毛片 | 国产精品夜色视频一区二区 | 久久久久久久久一级毛片 | 日韩a一级欧美一级在线播放 | 国产在线观看第一页 | 国产欧美一区二区三区沐欲 | 手机看片高清国产日韩片 | 手机在线观看精品国产片 | 久色精品| 91精品一区二区综合在线 | www.亚洲视频 | 特级毛片永久久免费观看 | 国产成人免费全部网站 | 老司机精品影院一区二区三区 | 日本又黄又爽又免费 | 亚洲精品h | 亚洲不卡一区二区三区在线 | 日本三级香港三级人妇gg在线 | 亚洲欧洲国产成人综合一本 | 亚洲天堂视频在线观看 | 欧美一级片在线播放 | 亚洲国产欧美目韩成人综合 | 国产亚洲精品久久久久久久久激情 | 亚洲日本高清 | 99热国产免费 | 成人99国产精品一级毛片 | 欧美一级鲁丝片免费看 | 国产亚洲高清在线精品不卡 | 加勒比色综合 | 日本不卡免费高清视频 | 国产成人精品日本亚洲麻豆 | 亚洲精品中文字幕一区 | 一级高清毛片免费a级高清毛片 | 日本高清色本在线www | 人妖欧美一区二区三区四区 | 国产在线视频自拍 |