Spring Boot 自定義 Shiro 過濾器,無法使用 @Autowired 解決方法

来源:https://www.cnblogs.com/nwgdk/archive/2019/06/21/11062229.html
-Advertisement-
Play Games

在 Spring Boot 中集成 Shiro,並使用 JWT 進行介面認證。 為了統一對 Token 進行過濾,所以自定義了一個 過濾器。 期間遇到了以下幾個問題,這裡逐一進行記錄,以備日後查閱。 問題一:JwtTokenFilter 無法使用 @Autowired 因為自定義了一個 JWT To ...


在 Spring Boot 中集成 Shiro,並使用 JWT 進行介面認證。

為了統一對 Token 進行過濾,所以自定義了一個 JwtTokenFilter 過濾器。

期間遇到了以下幾個問題,這裡逐一進行記錄,以備日後查閱。

問題一:JwtTokenFilter 無法使用 @Autowired

因為自定義了一個 JWT Token 工具類,用來解析和創建 Token,JwtTokenFilter 中需要用到此工具類,這裡本來可以直接手動進行 new 一個新的實例,但由於在 Spring 配置文件中定義了 JWT 簽名密鑰和過期時間,所以想使用 Spring @ConfigurationProperties 註解進行值得註入,所以這裡必須不能手動 new 一個新的實例。

所以在 ShiroConfiguration 配置文件中將 JwtTokenFilter 過濾器交由 Spring 管理:

@Bean
public JwtTokenFilter JwtTokenFilter() {
    return new JwtTokenFilter();
}

啟動項目進行測試,JwtTokenFilter 過濾器中 JwtUtil 類成功註入,但又遇到了另外一個問題。

問題二:anon 過濾器失效

在問題一解決後,登錄介面一直顯示需要認證,所以在只能將 ShiroFilterFactoryBean 中定義的 JwtTokenFilter 又改為原先手動 new:

@Bean(name = "shiroFilter")
public ShiroFilterFactoryBean shiroFilterFactoryBean() {
    ShiroFilterFactoryBean shiroFilterFactoryBean = new ShiroFilterFactoryBean();
    shiroFilterFactoryBean.setSecurityManager(securityManager());
    // 註冊自定義過濾器
    Map<String, Filter> filterMap = new LinkedHashMap<>(8);
    // 這裡只能使用 new 新建實例
    filterMap.put("authc", new JwtTokenFilter());
    shiroFilterFactoryBean.setFilters(filterMap);
    Map<String, String> filterChains = new LinkedHashMap<>(8);
    filterChains.put("/v1/admin/login", "anon");
    filterChains.put("/**", "authc");
    shiroFilterFactoryBean.setFilterChainDefinitionMap(filterChains);
    return shiroFilterFactoryBean;
}

接著創建一個 Spring 的上下文管理工具類,代碼如下:

package com.nwgdk.ums.common.util;

import org.springframework.beans.BeansException;
import org.springframework.context.ApplicationContext;
import org.springframework.context.ApplicationContextAware;
import org.springframework.stereotype.Component;

/**
 * Spring 上下文工具類
 *
 * @author nwgdk
 */
@Component
public class SpringContextUtil implements ApplicationContextAware {

    private static ApplicationContext applicationContext;

    @Override
    public void setApplicationContext(ApplicationContext applicationContext) throws BeansException {
        SpringContextUtil.applicationContext = applicationContext;
    }

    /**
     * 獲取上下文
     */
    public static ApplicationContext getApplicationContext() {
        return applicationContext;
    }

    /**
     * 通過 bena 名稱獲取上下文中的 bean
     */
    public static Object getBean(String name) {
        return applicationContext.getBean(name);
    }

    /**
     * 通過類型獲取上下文中的bean
     */
    public static Object getBean(Class<?> requiredType) {
        return applicationContext.getBean(requiredType);
    }
}

接著,在 JwtTokenFilter 過濾器中通過以上工具類獲取 JwtUtil 工具類:

if (StringUtils.isNotEmpty(jwtToken)) {
    if (jwtUtil == null) {
        jwtUtil = (JwtUtil) SpringContextUtil.getBean("jwtUtil");
    }
}

啟動項目進行測試,成功登錄。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • N皇後 難度分類 困難 題目描述 n皇後問題研究的是如何將 n個皇後放置在 n×n 的棋盤上,並且使皇後彼此之間不能相互攻擊。 上圖為 8 皇後問題的一種解法。 給定一個整數 n,返回所有不同的 n 皇後問題的解決方案。 每一種解法包含一個明確的 n 皇後問題的棋子放置方案,該方案中 'Q' 和 ' ...
  • 老男孩python全棧第三期視頻老男孩python全棧第三期視頻老男孩python全棧第三期視頻老男孩python全棧第三期視頻 老男孩python全棧第三期視頻老男孩python全棧第三期視頻老男孩python全棧第三期視頻老男孩python全棧第三期視頻 所屬網站分類: 資源下載 > pytho ...
  • 劉老師說這塊很重要。。。。。 應該是很重要,大概看了一下,這裡面關於views中函數作用,大概看來可能就是相應請求,傳入數據和跳轉,基本功能上貌似這些框架都差不多吧(其實我並沒用過3個框架以上。。。。) 從功能上想,網站必然包含了許多實現具體功能和數據展示的頁面,而現在在做的就是構成這些。 那麼一個 ...
  • 本文例子完整源碼地址:https://github.com/yu-linfeng/BlogRepositories/tree/master/repositories/sword 《【好書推薦】《劍指Offer》之軟技能》 《【好書推薦】《劍指Offer》之硬技能(編程題1~6)》 《【好書推薦】《劍 ...
  • Java語言的環境搭建 1.什麼是JDK和JRE? JDK(Java Development Kit:Java開發工具包): JDK是提供給Java開發人員使用的,其中包含了java的開發工具,也包括了JRE。所以安裝了JDK,就不用再單獨安裝JRE了。其中的開發工具有編譯工具(javac.exe) ...
  • 好久不見,風水輪流轉,我竟然寫寫寫python了 近日有個小需求,要求收集統計一些信息上報,並直接在後臺控制台列印,寫入日誌 為了美觀,需要以表格形式展現數據,形如 雖說可以用 prettytable 實現這個效果,不過還得安裝這個庫,需求比較簡單就不考慮安裝第三方依賴了,所以得自己寫 照著這個圖, ...
  • 分析出現no Session錯誤的原因以及給出解決方案: 使用SpringMVC + JSON數據返回時,經常會出現no Session的錯誤: 報錯原因:因為懶載入在提取關聯對象的屬性值的時候發現EntityManager已經被關閉,就報no session錯誤。 控制器類中的方法上添加了@Res ...
  • 策略模式:定義了不同的演算法,分別分裝起來,讓他們可以互相替換,即使演算法變化了,也不會影響到使用演算法的用戶 首先定義一個抽象演算法類,有兩個類繼承了這個抽象類,重寫了AlgorithmInterface()方法 用一個context類來維護對抽象演算法類Strategy對象的引用(重點) 測試類1 但是從 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...