单点登录cas与权限管理框架shiro集成-spring项目方式

       之前那篇文章介绍了普通web项目中单点登录cas与权限管理框架shiro集成方式,这里说下spring项目中的集成方式,首先还是配置一个filter

Java代码   收藏代码
  1. <filter>  
  2.         <filter-name>shiroFilter</filter-name>  
  3.         <filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class>  
  4.         <init-param>  
  5.             <param-name>targetFilterLifecycle</param-name>  
  6.             <param-value>true</param-value>  
  7.         </init-param>  
  8.     </filter>  
  9.       
  10.     <filter-mapping>  
  11.         <filter-name>shiroFilter</filter-name>  
  12.         <url-pattern>/*</url-pattern>  
  13.     </filter-mapping>  

 

       然后就是shiro的spring bean配置,其实就是把之前的shiro.ini的东西配成spring的bean,shiro-config.xml文件如下:

Java代码   收藏代码
  1. <beans xmlns="http://www.springframework.org/schema/beans"  
  2.     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:aop="http://www.springframework.org/schema/aop"  
  3.     xmlns:tx="http://www.springframework.org/schema/tx" xmlns:context="http://www.springframework.org/schema/context"  
  4.     xmlns:util="http://www.springframework.org/schema/util"  
  5.     xsi:schemaLocation="  
  6.      http://www.springframework.org/schema/beans   
  7.      http://www.springframework.org/schema/beans/spring-beans-3.0.xsd  
  8.      http://www.springframework.org/schema/context   
  9.      http://www.springframework.org/schema/context/spring-context-3.0.xsd  
  10.      http://www.springframework.org/schema/util  
  11.      http://www.springframework.org/schema/util/spring-util-3.0.xsd"  
  12.     default-lazy-init="true">  
  13.       
  14.     <bean id="shiroFilter" class="org.apache.shiro.spring.web.ShiroFilterFactoryBean">  
  15.         <property name="securityManager" ref="securityManager"/>  
  16.         <!-- 设定角色的登录链接,这里为cas登录页面的链接可配置回调地址  -->  
  17.         <property name="loginUrl" value="https://www.cas.com/login?service=http://www.example.com/shiro-cas" />  
  18.           
  19.         <property name="filters">  
  20.             <util:map>  
  21.                 <!-- 添加casFilter到shiroFilter -->  
  22.                 <entry key="casFilter" value-ref="casFilter"/>  
  23.             </util:map>  
  24.         </property>   
  25.         <property name="filterChainDefinitions">  
  26.             <value>                 
  27.                 /shiro-cas = casFilter  
  28.                 /admin/** = roles[ROLE_USER]  
  29.                 /** = anon  
  30.             </value>  
  31.         </property>  
  32.     </bean>  
  33.       
  34.     <bean id="casFilter" class="org.apache.shiro.cas.CasFilter">  
  35.         <!-- 配置验证错误时的失败页面  -->  
  36.         <property name="failureUrl" value="/error.jsp"/>  
  37.     </bean>  
  38.       
  39.     <bean id="casRealm" class="org.apache.shiro.cas.CasRealm">  
  40.         <property name="defaultRoles" value="ROLE_USER"/>       
  41.         <property name="casServerUrlPrefix" value="https://www.cas.com"/>  
  42.         <!-- 客户端的回调地址设置,必须和下面的shiro-cas过滤器拦截的地址一致 -->  
  43.         <property name="casService" value="http://www.example.com/shiro-cas"/>  
  44.     </bean>  
  45.       
  46.     <bean id="securityManager" class="org.apache.shiro.web.mgt.DefaultWebSecurityManager">      
  47.         <property name="realm" ref="casRealm"/>  
  48.         <property name="subjectFactory" ref="casSubjectFactory"/>  
  49.     </bean>  
  50.       
  51.     <!-- 如果要实现cas的remember me的功能,需要用到下面这个bean,并设置到securityManager的subjectFactory中 -->  
  52.     <bean id="casSubjectFactory" class="org.apache.shiro.cas.CasSubjectFactory"/>  
  53.   
  54.       
  55.     <bean id="lifecycleBeanPostProcessor" class="org.apache.shiro.spring.LifecycleBeanPostProcessor"/>  
  56.   
  57.     <bean class="org.springframework.beans.factory.config.MethodInvokingFactoryBean">  
  58.         <property name="staticMethod" value="org.apache.shiro.SecurityUtils.setSecurityManager"/>  
  59.         <property name="arguments" ref="securityManager"/>  
  60.     </bean>  
  61. </beans>  

 


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值