Apache Shiro 框架簡(jiǎn)介
一、什么是Shiro
Apache Shiro是一個(gè)強(qiáng)大易用的Java安全框架,提供了認(rèn)證、授權(quán)、加密和會(huì)話管理等功能:
- 認(rèn)證 - 用戶身份識(shí)別,常被稱為用戶“登錄”;
- 授權(quán) - 訪問(wèn)控制;
- 密碼加密 - 保護(hù)或隱藏?cái)?shù)據(jù)防止被偷窺;
- 會(huì)話管理 - 每用戶相關(guān)的時(shí)間敏感的狀態(tài)。
對(duì)于任何一個(gè)應(yīng)用程序,Shiro都可以提供全面的安全管理服務(wù)。并且相對(duì)于其他安全框架,Shiro要簡(jiǎn)單的多。
二、Shiro的架構(gòu)介紹
首先,來(lái)了解一下Shiro的三個(gè)核心組件:Subject, SecurityManager 和 Realms. 如下圖:

Subject:即“當(dāng)前操作用戶”。但是,在Shiro中,Subject這一概念并不僅僅指人,也可以是第三方進(jìn)程、后臺(tái)帳戶(Daemon Account)或其他類似事物。它僅僅意味著“當(dāng)前跟軟件交互的東西”。但考慮到大多數(shù)目的和用途,你可以把它認(rèn)為是Shiro的“用戶”概念。
Subject代表了當(dāng)前用戶的安全操作,SecurityManager則管理所有用戶的安全操作。
SecurityManager:它是Shiro框架的核心,典型的Facade模式,Shiro通過(guò)SecurityManager來(lái)管理內(nèi)部組件實(shí)例,并通過(guò)它來(lái)提供安全管理的各種服務(wù)。
Realm: Realm充當(dāng)了Shiro與應(yīng)用安全數(shù)據(jù)間的“橋梁”或者“連接器”。也就是說(shuō),當(dāng)對(duì)用戶執(zhí)行認(rèn)證(登錄)和授權(quán)(訪問(wèn)控制)驗(yàn)證時(shí),Shiro會(huì)從應(yīng)用配置的Realm中查找用戶及其權(quán)限信息。
從這個(gè)意義上講,Realm實(shí)質(zhì)上是一個(gè)安全相關(guān)的DAO:它封裝了數(shù)據(jù)源的連接細(xì)節(jié),并在需要時(shí)將相關(guān)數(shù)據(jù)提供給Shiro。當(dāng)配置Shiro時(shí),你必須至少指定一個(gè)Realm,用于認(rèn)證和(或)授權(quán)。配置多個(gè)Realm是可以的,但是至少需要一個(gè)。
Shiro內(nèi)置了可以連接大量安全數(shù)據(jù)源(又名目錄)的Realm,如LDAP、關(guān)系數(shù)據(jù)庫(kù)(JDBC)、類似INI的文本配置資源以及屬性文件等。如果缺省的Realm不能滿足需求,你還可以插入代表自定義數(shù)據(jù)源的自己的Realm實(shí)現(xiàn)。
Shiro完整架構(gòu)圖:

除前文所講Subject、SecurityManager 、Realm三個(gè)核心組件外,Shiro主要組件還包括:
Authenticator :認(rèn)證就是核實(shí)用戶身份的過(guò)程。這個(gè)過(guò)程的常見(jiàn)例子是大家都熟悉的“用戶/密碼”組合。多數(shù)用戶在登錄軟件系統(tǒng)時(shí),通常提供自己的用戶名(當(dāng)事人)和支持他們的密碼(證書(shū))。如果存儲(chǔ)在系統(tǒng)中的密碼(或密碼表示)與用戶提供的匹配,他們就被認(rèn)為通過(guò)認(rèn)證。
Authorizer :授權(quán)實(shí)質(zhì)上就是訪問(wèn)控制 - 控制用戶能夠訪問(wèn)應(yīng)用中的哪些內(nèi)容,比如資源、Web頁(yè)面等等。
SessionManager :在安全框架領(lǐng)域,Apache Shiro提供了一些獨(dú)特的東西:可在任何應(yīng)用或架構(gòu)層一致地使用Session API。即,Shiro為任何應(yīng)用提供了一個(gè)會(huì)話編程范式 - 從小型后臺(tái)獨(dú)立應(yīng)用到大型集群Web應(yīng)用。這意味著,那些希望使用會(huì)話的應(yīng)用開(kāi)發(fā)者,不必被迫使用Servlet或EJB容器了?;蛘?,如果正在使用這些容器,開(kāi)發(fā)者現(xiàn)在也可以選擇使用在任何層統(tǒng)一一致的會(huì)話API,取代Servlet或EJB機(jī)制。
CacheManager :對(duì)Shiro的其他組件提供緩存支持。
總結(jié)
以上所述是小編給大家介紹的Apache Shiro 框架簡(jiǎn)介,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
- 讓Apache Shiro保護(hù)你的應(yīng)用
- Apache Shiro 使用手冊(cè)(五) Shiro 配置說(shuō)明
- Apache Shiro 使用手冊(cè)(四) Realm 實(shí)現(xiàn)
- Apache Shiro 使用手冊(cè)(三) Shiro授權(quán)
- Apache Shiro 使用手冊(cè)(二) Shiro 認(rèn)證
- Apache Shiro 使用手冊(cè)(一) Shiro架構(gòu)介紹
- 關(guān)于Apache shiro實(shí)現(xiàn)一個(gè)賬戶同一時(shí)刻只有一個(gè)人登錄(shiro 單點(diǎn)登錄)
相關(guān)文章
Linux進(jìn)程管理之如何創(chuàng)建和銷毀進(jìn)程
這篇文章主要介紹了Linux進(jìn)程管理之如何創(chuàng)建和銷毀進(jìn)程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-02-02
Linux命令行解釋器的模擬實(shí)現(xiàn)過(guò)程
平時(shí)使用指令操作linux系統(tǒng)的時(shí)候可能會(huì)輸入一些不好的指令,這些指令可能會(huì)對(duì)操作系統(tǒng)內(nèi)核造成影響,所以就有了命令行解釋器這個(gè)東西,本文小編給大家介紹了Linux命令行解釋器的模擬實(shí)現(xiàn)過(guò)程,需要的朋友可以參考下2025-04-04
CentOS7服務(wù)器環(huán)境下vsftpd安裝及配置方法
這篇文章主要介紹了CentOS7服務(wù)器環(huán)境下vsftpd安裝及配置方法,結(jié)合實(shí)例形式分析了CentOS7服務(wù)器環(huán)境下進(jìn)行vsftpd安裝及配置的步驟與相關(guān)問(wèn)題解決方法,需要的朋友可以參考下2018-03-03
Linux 平臺(tái)安裝python3.7.0環(huán)境示例【圖文說(shuō)明】
這篇文章主要介紹了Linux 平臺(tái)安裝python3.7.0環(huán)境的方法,需要的朋友可以參考下2016-10-10
解決centos7操作系統(tǒng)開(kāi)機(jī)提示error:file“/boot/grub/i386-pc/normal.mod“no
公司重要業(yè)務(wù)虛擬機(jī)啟動(dòng)失敗,提示找不到normal.mod文件,通過(guò)救援模式下手動(dòng)設(shè)置grub啟動(dòng)分區(qū)和路徑,加載基本模塊,最終成功進(jìn)入正常模式并引導(dǎo)系統(tǒng)2024-12-12
Linux下ulimit關(guān)于open files的配置過(guò)程
本文介紹了在CentOS系統(tǒng)中設(shè)置文件描述符和進(jìn)程限制的方法,包括/etc/security/limits.conf文件和systemd的system.conf文件的配置,這些設(shè)置對(duì)于大數(shù)據(jù)系統(tǒng)的穩(wěn)定運(yùn)行至關(guān)重要2024-12-12
Linux平臺(tái)Segmentation fault(段錯(cuò)誤)調(diào)試過(guò)程
這篇文章主要介紹了Linux平臺(tái)Segmentation fault(段錯(cuò)誤)調(diào)試過(guò)程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-09-09

