Spring 集成Shiro(XML方式)--官网

Spring 集成Shiro(XML方式)

Shiro中的组件都是JavaBean形式实现的,因此可以通过Spring的XML或其他Spring的配置机制来设置这些组件。首先,Shiro应用程序需要一个单例的SecurityManager实例,但这并不表示它是静态的,只需要确保它在应用程序中是唯一的即可

非Web应用

下面展示了非Web应用如何配置一个单例的SecurityManager实例

<!-- 定义Realm -->
<bean id="myRealm" class="...">
    ...
</bean>

<bean id="securityManager" class="org.apache.shiro.mgt.DefaultSecurityManager">
    <!-- 这里我们只设置了一个realm,如果想要配置一个多realm的应用,则设置realms属性即可 -->
    <property name="realm" ref="myRealm" />
</bean>

<bean id="lifecycleBeanPostProcessor" class="org.apache.shiro.spring.LifeCycleBeanPostProcessor"/>

<!-- 最简单的让SecurityUtils.*方法起作用的方式,就是将SecurityManager的bean设置为静态单例 -->
<bean class="org.springframework.beans.factory.config.MethodInvokingFactoryBean">
    <property name="staticMethod" value="org.apache.shiro.SecurityUtils.setSecurityManager"/>
    <property name="arguments" ref="securityManager" />
</bean>

Web 应用

在Web应用中,所有的Web请求都要经过Shiro的过滤器

Shiro1.0之前,需要采用一种混合的方式来配置Spring Web项目,即在web.xml中定义和配置Shiro的过滤器,而在Spring的XML中定义SecurityManager。这样就不能将自己的配置合并到一个地方,也不能利用更高级的Spring特性(如PropertyPlaceholderConfigurer或抽象bean)的配置能力来合并公共配置

现在在Shiro 1.0和更高版本中,所有Shiro配置都是在Spring XML中完成的,提供了对更健壮的Spring配置机制的访问

web.xml

除了之前Web章节的web.xml元素之外,Spring Web项目还需要定义以下过滤器

<!-- 这个shiroFilter和applicationContext.xml中定义的Bean名字匹配 -->
<filter>
    <filter-name>shiroFilter</filter-name>
    <filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class>
    <init-param>
        <param-name>targetFilterLifecycle</param-name>
        <param-value>true</param-value>
    </init-param>
</filter>
...
<!-- 确保所有的请求都能经过过滤,通常这个filter-mapping定义在最前面,确保请求在到达其他过滤器之前先经过shiroFilter -->
<filter-mapping>
    <filter-name>shiroFilter</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>

完整示例参见github

applicationContext.xml

<bean id="shiroFilter" class="org.apache.shiro.spring.web.ShiroFilterFactoryBean" >
    <property name="securityManager" ref="securityManager"></property>
    <!-- 根据需要配置如下属性
    <property name="loginUrl" value="/login.jsp" />
    <property name="successUrl" value="/home.jsp" />
    <property name="unauthorizedUrl" value="/unauthorized.jsp"/> -->
    
    <!-- 
        还记得前面的通过ini将Shiro配置到web项目中时,我们通过过滤器的名字来定义一条过滤器链
        shiroFilter会自动获取所有声明的javax.servlet.Filter的bean定义,将这些bean设置到filters属性中,其默认的key就是它的beanName,这样就可以通过这个key来定义过滤器链了
        当然也可以覆盖整个默认选项
    <property name="filters">
        <util:map>
            <entry key="anAlias" value-ref="someFilter" />
        </util:map>
    </property>
    -->
    
    <property name="filterChainDefinitions">
        <value>
            # 这里是一些过滤器链的例子
            /admin/** = authc, roles[admin]
            /docs/** = authc, perms[document:read]
            /** = authc
            # 其他例子
        </value>
        <!-- 可以看到,这里的value其实就是ini配置中的url内容 -->
    </property>
</bean>

<!-- 可以在应用程序上下文的任意一个位置定义javax.servlet.Filter的bean,它们会自动的设置到shiroFilter的filters属性中 -->
<bean id="someFilter" class="..." />
<bean id="anotherFilter" class="...">...</bean>
...

<bean id="securityManager" class="org.apache.shiro.web.mgt.DefaultWebSecurityManager">
    <!-- 这里示例是一个单realm的应用,也可以通过realms属性值设置多realm应用 -->
    <property name="realm" ref="myRealm"/>
    
    <!-- sessionMode属性值决定了是否启用Shiro的原生会话管理,默认采用的是Servlet容器的会话管理 -->
    <property name="sessionMode" value="native"/>
</bean>

<bean id="lifecycleBeanPostProcessor" class="org.apache.shiro.spring.LifecycleBeanPostProcessor" />

<!-- 定义一个realm -->
<bean id="myRealm" class="...">
    ...
</bean>

开启Shiro的注解支持

无论是Web应用还是非Web应用,想要开启Shiro的注解支持,都需要Spring的AOP集成来支持

<!-- 为Spring配置的bean启动开启Shiro注解支持 -->
<bean class="org.springframework.aop.framework.autoproxy.DefaultAdvisorAutoProxyCreator" depends-on="lifecycleBeanPostProcessor" />

<bean class="org.apache.shiro.spring.security.interceptor.AuthorizationAttributeSourceAdvisor">
    <property name="securityManager" ref="securityManager" />
</bean>

保护Spring的远程调用

Shiro的Spring远程支持分为两部分:进行远程调用的客户端配置和接收处理远程调用的服务器配置

服务端配置

当一个远程调用到达服务端时,服务端必须绑定相关联的Subject到执行线程中,这个是由Shiro的SecureRemoteInvocationExecutor实例完成的

<!-- 确保任何Spring的远程调用都能绑定一个用于安全检查的Subject -->
<bean id="secureRemoteInvocationExecutor" class="org.apache.shiro.spring.remoting.SecureRemoteInvocationExecutor">
    <property name="securityManager" ref="seucrityManager" />
</bean>

一旦定义了此bean,必须将其设置到用于导出/公开服务的ExporterExporter的实现是根据使用中的远程处理机制/协议定义的。下面展示了一个基于HTTP的远程服务的例子

<bean name="/someService" class="org.springframework.remoting.httpinvoker.HttpInvokerServiceExporter" >
    <property name="service" ref="someService"/>
    <property name="serviceInterface" value="com.pkg.service.SomeService"/>
    <property name="remoteInvocationExecutor" ref="secureRemoteInvocationExecutor"/>
</bean>

客户端配置

当一个远程调用发生时,客户端必须将Subject的标识信息附加到远程调用中,让服务器知道谁在调用。如果这个客户端是一个基于Spring的客户端,则可以通过Shiro的SecureRemoteInvocationFactory来完成这些操作

<bean id="secureRemoteInvocationFactory" class="org.apache.shiro.spring.remoting.SecureRemoteInvocationFactory" />

最后,将这个bean设置到协议相关的Spring远程ProxyFactoryBean就可以了。下面的配置展示了一个基于HTTP的远程调用

<bean id="someService" class="org.springframework.remoting.httpinvoker.HttpInvokerProxyFactoryBean" >
    <property name="serviceUrl" value="http://host:port/remoting/someService" />
    <property name="serviceInterface" value="com.pkg.service.SomeService" />
    <property name="remoteInvocationFactory" ref="secureRemoteInvocationFactory" />
</bean>
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,980评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,178评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,868评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,498评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,492评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,521评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,910评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,569评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,793评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,559评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,639评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,342评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,931评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,904评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,144评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,833评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,350评论 2 342

推荐阅读更多精彩内容