CAS-shiro 相关配置

本文档记录了在公司项目中整合CAS单点登录与Shiro权限框架的步骤。内容包括 CAS 和 Shiro 的集成配置,以及需要注意的细节,旨在帮助开发者了解如何在基于Maven的项目中设置相关依赖和自定义casRealm。

   最近公司要整合CAS单点登录,权限框架使用的是shiro(不了解的同学可以去看看,很方便的一个轻量级框架),CAS之前也做过,但之前没有使用shiro这套框架,所以这里记录下CAS与Shiro的集成步骤以及需要注意到的地方。

1.首先当然是下载相关jar包,我们项目是maven结构的,这里给出pom文件配置示例

       <dependency>
    		<groupId>org.apache.shiro</groupId>
    		<artifactId>shiro-cas</artifactId>
    		<version>1.2.5</version>
	</dependency>
	<dependency>
    		<groupId>org.jasig.cas.client</groupId>
    		<artifactId>cas-client-core</artifactId>
    		<version>3.2.1</version>
	</dependency>
:本文主要用来记录CAS与Shiro的集成配置,所以CAS相关内容不做描述。


2.定义casRealm 示例如下

public class CustomRealm extends CasRealm{
	
	private static final Logger logger = LoggerFactory.getLogger(CustomRealm.class);

	@Override
    protected AuthorizationInfo doGetAuthorizationInfo(PrincipalCollection principals) {
        String username = (String)principals.getPrimaryPrincipal();

        SimpleAuthorizationInfo authorizationInfo = new SimpleAuthorizationInfo();
       /* authorizationInfo.setRoles(userService.findRoles(username));
        authorizationInfo.setStringPermissions(userService.findPermissions(username));*/

        return authorizationInfo;
    }
	
	
	@Override
    protected AuthenticationInfo doGetAuthenticationInfo(AuthenticationToken token) throws AuthenticationException {
        CasToken casToken = (CasToken) token;
        if (token == null) {
            return null;
        }
        
        String ticket = (String)casToken.getCredentials();
        if (!StringUtils.hasText(ticket)) {
            return null;
        }
        
        TicketValidator ticketValidator = ensureTicketValidator();

        try {
            // 验证票据是否有效
            Assertion casAssertion = ticketValidator.validate(ticket, getCasService());
            // 获取返回信息
            AttributePrincipal casPrincipal = casAssertion.getPrincipal();
            String userId = casPrincipal.getName();
            logger.debug("Validate ticket : {} in CAS server : {} to retrieve user : {}", new Object[]{
                    ticket, getCasServerUrlPrefix(), userId
            });
            //获取配置的返回信息
            Map attributes = casPrincipal.getAttributes();
            casToken.setUserId(userId);
            String rememberMeAttributeName = getRememberMeAttributeName();
            String rememberMeStringValue = (String)attributes.get(rememberMeAttributeName);
            boolean isRemembered = rememberMeStringValue != null && Boolean.parseBoolean(rememberMeStringValue);
            if (isRemembered) {
                casToken.setRememberMe(true);
            }
            //List principals = CollectionUtils.asList(userId, attributes);
            //设置登录成功返回值到shiro subject中
            PrincipalCollection principalCollection = new SimplePrincipalCollection(attributes, getName());
            return new SimpleAuthenticationInfo(principalCollection, ticket);
        } catch (TicketValidationException e) { 
            throw new CasAuthenticationException("Unable to validate ticket [" + ticket + "]", e);
        }
    }
}


3.spring-shiro.xml相关配置


     	
    
		
		
		
		
		
		
		
		
		
	
	
	
		
	

    
	  
            
	  

	
		
		
		
			
				
				 
			
		
		
			
				/casFailure.jsp = anon
				/cas = cas
				/logout = logout
				/** = user
			
		
	
      
      
    
    
    
      
 
    
     
    

    
    
        
        
        
    

    
        
        
        
    

    
    
        
        
        
    

    
    
        
        
        
    
    
      
	  
   	 	  
   	 	  
   	 	  
   	 	  
    	  
    	  
    	  
	 

	  
	  
    	  
    	  
	
	  
	  
    	  
    	  
	

    
    
        
        
    

4.修改cas服务端的配置,使其支持登出跳转
cas-servlet.xml 中找到节点 logoutAction  修改  followServiceRedirects属性为true

5.由于cas单点登录只会注销掉 web session  而shiro的session 需要我们自己注销,这里我参考了修改 单点登出过滤器与监听器的方式  
自定义了 SingleSignOutFilter 与SingleSignOutHttpSessionListener  
doFilter 添加注销 shiro session代码
    
          handler.destroySession(request);
            //调用shiro的logout方法
            log.debug("subject.logout() --start");
            Subject subject = SecurityUtils.getSubject();
            subject.logout();
            log.debug("subject.logout() --end");
 
  



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值