一、什么是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ù)。
源碼獲取請(qǐng)加求求(企鵝):2042849237
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的其他組件提供緩存支持绽乔。
更多詳細(xì)源碼參考來(lái)源:http://minglisoft.cn/technology?歡迎大家一起學(xué)習(xí)研究相關(guān)技術(shù),源碼獲取請(qǐng)加求求(企鵝):2042849237