Spring Security實戰(zhàn)三:說說我的認(rèn)識

Spring Security的用法看了不少纺蛆,就大概來總結(jié)總結(jié)算利,找出一套適合直接應(yīng)用到項目的。

一证薇、為什么要用Spring Security

待補充

二度苔、Spring Security整合中的缺點

??Spring Security的主要功能是登錄驗證、訪問控制浑度。然而寇窑,由于Remember Me和訪問控制自身的缺陷,導(dǎo)致并不適用在實際的項目中俺泣。Remember Me的缺陷參考上篇文章:關(guān)于記住HTTP請求的狀態(tài)疗认;訪問控制的不足完残,主要是因為要把權(quán)限控制硬編碼在代碼中伏钠。為了解決這兩個問題,考慮引入JWT+redis(JWT)和RBAC谨设。

1.引入JWT+redis

??1)講講JWT的優(yōu)缺點熟掂。2)引入redis解決其刷新的問題有兩種方式。①時時更新 ②保存一個上次訪問時間扎拣,在JWT過期時赴肚,比較兩次時間的差值來確定,是否需要動態(tài)更新JWT二蓝。
待補充

2.引入RBAC

??RBAC的引入分三步:先設(shè)計數(shù)據(jù)庫誉券,再編寫增刪改查操作,最后將RBAC應(yīng)用到Spring Security中刊愚。前兩步就省略了踊跟,直接看第三步吧,怎么在Spring Security中使用RBAC鸥诽。
首先商玫,判斷當(dāng)前用戶所擁有的URL是否和當(dāng)前訪問的URL是否匹配

/**
 * 返回權(quán)限驗證的接口
 */
public interface RbacService {
      boolean hasPermission(HttpServletRequest request,Authentication authentication);
}

@Component("rbacService")
public class RbacServiceImpl implements RbacService {
      private AntPathMatcher antPathMatcher = new AntPathMatcher();
      @Override
      public boolean hasPermission(HttpServletRequest request, Authentication authentication) {
            Object principal = authentication.getPrincipal();
            boolean hasPermission = false;
            if (principal instanceof UserDetails) { //首先判斷先當(dāng)前用戶是否是我們UserDetails對象箕憾。
                  String userName = ((UserDetails) principal).getUsername();
                  Set<String> urls = new HashSet<>(); // 數(shù)據(jù)庫讀取 //讀取用戶所擁有權(quán)限的所有URL
                  
                  urls.add("/whoim");
                  // 注意這里不能用equal來判斷,因為有些URL是有參數(shù)的拳昌,所以要用AntPathMatcher來比較
                  for (String url : urls) {
                        if (antPathMatcher.match(url, request.getRequestURI())) {
                              hasPermission = true;
                              break;
                        }
                  }
            }
            return hasPermission;
      }
}

然后將此訪問控制配置在Spring Security中

@Override
    protected void configure(HttpSecurity http) throws Exception {
        http.formLogin()  //表單登錄
                //.loginPage("/evolutionary-loginIn.html")
                .loginPage("/logintype") //如果需要身份認(rèn)證則跳轉(zhuǎn)到這里
                .loginProcessingUrl("/login")
                .successHandler(evolutionaryAuthenticationHandler)
                .failureHandler(evolutionaryAuthenticationFailureHandler)
                .and()
                .authorizeRequests()
                .antMatchers("/logintype",securityProperties.getBrower().getLoginPage())//不校驗我們配置的登錄頁面
                .permitAll()
                .anyRequest()
                .access("@rbacService.hasPermission(request,authentication)")    //必須經(jīng)過認(rèn)證以后才能訪問
                .and().csrf().disable().addFilter(new JWTLoginFilter(authenticationManager()))
                .addFilter(new JWTAuthenticationFilter(authenticationManager()));
    }
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末袭异,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子炬藤,更是在濱河造成了極大的恐慌御铃,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,607評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件沈矿,死亡現(xiàn)場離奇詭異畅买,居然都是意外死亡,警方通過查閱死者的電腦和手機细睡,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,239評論 3 395
  • 文/潘曉璐 我一進(jìn)店門谷羞,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人溜徙,你說我怎么就攤上這事湃缎。” “怎么了蠢壹?”我有些...
    開封第一講書人閱讀 164,960評論 0 355
  • 文/不壞的土叔 我叫張陵嗓违,是天一觀的道長。 經(jīng)常有香客問我图贸,道長蹂季,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,750評論 1 294
  • 正文 為了忘掉前任疏日,我火速辦了婚禮偿洁,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘沟优。我一直安慰自己涕滋,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,764評論 6 392
  • 文/花漫 我一把揭開白布挠阁。 她就那樣靜靜地躺著宾肺,像睡著了一般。 火紅的嫁衣襯著肌膚如雪侵俗。 梳的紋絲不亂的頭發(fā)上锨用,一...
    開封第一講書人閱讀 51,604評論 1 305
  • 那天,我揣著相機與錄音隘谣,去河邊找鬼增拥。 笑死,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的跪者。 我是一名探鬼主播棵帽,決...
    沈念sama閱讀 40,347評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼渣玲!你這毒婦竟也來了逗概?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,253評論 0 276
  • 序言:老撾萬榮一對情侶失蹤忘衍,失蹤者是張志新(化名)和其女友劉穎逾苫,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體枚钓,經(jīng)...
    沈念sama閱讀 45,702評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡铅搓,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,893評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了搀捷。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片星掰。...
    茶點故事閱讀 40,015評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖嫩舟,靈堂內(nèi)的尸體忽然破棺而出氢烘,到底是詐尸還是另有隱情,我是刑警寧澤家厌,帶...
    沈念sama閱讀 35,734評論 5 346
  • 正文 年R本政府宣布播玖,位于F島的核電站,受9級特大地震影響饭于,放射性物質(zhì)發(fā)生泄漏蜀踏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,352評論 3 330
  • 文/蒙蒙 一掰吕、第九天 我趴在偏房一處隱蔽的房頂上張望果覆。 院中可真熱鬧,春花似錦畴栖、人聲如沸随静。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,934評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至恋捆,卻和暖如春照皆,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背沸停。 一陣腳步聲響...
    開封第一講書人閱讀 33,052評論 1 270
  • 我被黑心中介騙來泰國打工膜毁, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 48,216評論 3 371
  • 正文 我出身青樓瘟滨,卻偏偏與公主長得像候醒,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子杂瘸,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,969評論 2 355