成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Spring Security中利用JWT退出登錄大部分人都寫錯了配置

開發 架構
使用了JWT后,每次請求都要攜帶Bearer Token并且被專門的過濾器攔截解析之后才能將用戶認證信息保存到SecurityContext中去。

[[428800]]

最近有個粉絲提了個問題,說他在Spring Security中用JWT做退出登錄的時無法獲取當前用戶,導致無法證明“我就是要退出的那個我”,業務失敗!經過我一番排查找到了原因,而且這個錯誤包括我自己的大部分人都犯過。

Session會話

之所以要說Session會話,是因為Spring Security默認配置就是有會話的,所以當你登錄以后Session就會由服務端保持直到你退出登錄。只要Session保持住,你的請求只要進入服務器就可以從ServletRequest中獲取到當前的HttpSession,然后會根據HttpSession來加載當前的SecurityContext。相關的邏輯在Spring Security默認的過濾器SecurityContextPersistenceFilter中,有興趣可以看相關的源碼。

而且默認情況下SecurityContextPersistenceFilter的優先級是高于退出過濾器LogoutFilter的,所以能夠保證有Session會話的情況下退出一定能夠獲取當前用戶。

無Session會話

使用了JWT后,每次請求都要攜帶Bearer Token并且被專門的過濾器攔截解析之后才能將用戶認證信息保存到SecurityContext中去。參考Spring Security實戰干貨教程中的Token認證實現JwtAuthenticationFilter,相關邏輯為:

  1. // 當token匹配          
  2.   if (jwtToken.equals(accessToken)) { 
  3.          // 解析 權限集合  這里 
  4.        JSONArray jsonArray = jsonObject.getJSONArray("roles"); 
  5.        List<String> roles = jsonArray.toList(String.class); 
  6.        String[] roleArr = roles.toArray(new String[0]); 
  7.  
  8.        List<GrantedAuthority> authorities = AuthorityUtils.createAuthorityList(roleArr); 
  9.        User user = new User(username, "[PROTECTED]", authorities); 
  10.        // 構建用戶認證token 
  11.        UsernamePasswordAuthenticationToken usernamePasswordAuthenticationToken = new UsernamePasswordAuthenticationToken(usernull, authorities); 
  12.        usernamePasswordAuthenticationToken.setDetails(new WebAuthenticationDetailsSource().buildDetails(request)); 
  13.        // 放入安全上下文中 
  14.        SecurityContextHolder.getContext().setAuthentication(usernamePasswordAuthenticationToken); 
  15.    } else { 
  16.        // token 不匹配 
  17.        if (log.isDebugEnabled()){ 
  18.            log.debug("token : {}  is  not in matched", jwtToken); 
  19.        } 
  20.  
  21.        throw new BadCredentialsException("token is not matched"); 
  22.    } 

為什么退出登錄無法獲取當前用戶

分析了兩種情況下用戶認證信息的安全上下文配置后,我們回到問題的本身。來看看為什么用JWT會出現無法獲取當前認證信息的原因。在HttpSecurity中,那位同學是這樣配置JwtAuthenticationFilter的順序的:

  1. httpSecurity.addFilterBefore(jwtAuthenticationFilter, UsernamePasswordAuthenticationFilter.class) 

我們再看看Spring Security過濾器排序圖:

Spring Security過濾器排序

也就說LogoutFilter執行退出的時候,JWT還沒有被JwtAuthenticationFilter攔截,當然無法獲取當前認證上下文SecurityContext。

解決方法

解決方法就是必須在LogoutFilter執行前去解析JWT并將成功認證的信息存到SecurityContext。我們可以這樣配置:

httpSecurity.addFilterBefore(jwtAuthenticationFilter, LogoutFilter.class)

這樣問題就解決了,你只要實現把當前JWT作廢掉就退出登錄了。

本文轉載自微信公眾號「碼農小胖哥」,可以通過以下二維碼關注。轉載本文請聯系碼農小胖哥公眾號。

 

責任編輯:武曉燕 來源: 碼農小胖哥
相關推薦

2022-05-18 09:49:26

MySQLID數據庫

2025-01-26 16:04:09

2019-10-11 10:05:30

程序員固態硬盤Google

2024-09-04 01:36:51

Java對象傳遞

2021-08-06 17:44:45

云安全云計算網絡安全

2018-11-25 21:53:10

人工智能AI開發者

2012-06-07 16:16:43

JavaScript

2013-07-30 11:15:35

NASA云計算安全云計算

2016-12-12 18:45:08

Data Mining大數據

2016-10-26 10:23:42

2023-02-07 13:51:11

SQLupdate語句

2019-09-12 09:56:13

程序員技能開發者

2016-12-22 08:38:21

2011-12-26 17:13:18

iPad統計App

2015-11-25 10:48:44

JS閉包面試題

2023-08-07 11:56:43

模型人貨場數據

2024-07-05 11:50:15

2025-06-04 11:06:54

比特幣區塊鏈挖礦

2018-08-31 07:33:58

2010-11-18 12:44:25

LibreOffice
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 美国一级片在线观看 | 激情 一区 | 一区二区久久精品 | 国产一区三区在线 | 91精品国产综合久久久久蜜臀 | 久久麻豆精品 | 成人精品鲁一区一区二区 | 国产视频精品在线 | 国产激情免费视频 | 午夜爽爽爽男女免费观看影院 | 成人精品一区二区三区中文字幕 | 欧美精品a∨在线观看不卡 欧美日韩中文字幕在线播放 | 天天干天天插 | 亚洲精品视频网站在线观看 | 亚洲精品欧美 | 97精品超碰一区二区三区 | 午夜精品一区二区三区在线视频 | 久久91 | 国产精品久久 | 亚洲国产精品久久 | 亚洲第一福利视频 | 国产在线中文字幕 | 亚洲精品日韩在线 | 国产精品久久久久一区二区三区 | 一级片免费视频 | 美女在线国产 | 亚洲欧美综合 | 天天操夜夜操 | 久久精品国产一区老色匹 | 99热在线免费 | 人人看人人射 | 国产视频精品免费 | 91精品久久久 | 一区二区三区免费网站 | 国内自拍偷拍 | 国产精品久久久久久久久久三级 | 欧美一区不卡 | 国产男女精品 | 国产精品欧美一区二区三区 | 亚洲网站在线观看 | 91麻豆精品国产91久久久久久 |