zoukankan      html  css  js  c++  java
  • Cas单点登录配置数据查询用户

    <?xml version="1.0" encoding="UTF-8"?>
    <beans xmlns="http://www.springframework.org/schema/beans"
           xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
           xmlns:context="http://www.springframework.org/schema/context"
           xmlns:p="http://www.springframework.org/schema/p"
           xmlns:c="http://www.springframework.org/schema/c"
           xmlns:aop="http://www.springframework.org/schema/aop"
           xmlns:tx="http://www.springframework.org/schema/tx"
           xmlns:util="http://www.springframework.org/schema/util"
           xmlns:sec="http://www.springframework.org/schema/security"
           xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
           http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd
           http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.xsd
           http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd
           http://www.springframework.org/schema/security http://www.springframework.org/schema/security/spring-security.xsd
           http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util.xsd">
    
        <!-- 引入配置文件 -->
    <!--     <bean id="propertyConfigurer" -->
    <!--           class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> -->
    <!--         <property name="location" value="classpath:redis.properties" /> -->
    <!--     </bean> -->
        
        <util:map id="authenticationHandlersResolvers">
            <entry key-ref="proxyAuthenticationHandler" value-ref="proxyPrincipalResolver" />
            <entry key-ref="primaryAuthenticationHandler" value-ref="primaryPrincipalResolver" />
        </util:map>
    
        <util:list id="authenticationMetadataPopulators">
            <ref bean="successfulHandlerMetaDataPopulator" />
            <ref bean="rememberMeAuthenticationMetaDataPopulator" />
        </util:list>
    
        <bean id="attributeRepository" class="org.jasig.services.persondir.support.NamedStubPersonAttributeDao"
              p:backingMap-ref="attrRepoBackingMap" />
    
        <!-- <alias name="acceptUsersAuthenticationHandler" alias="primaryAuthenticationHandler" /> -->
        
        <!--begin 从数据库中的用户表中读取 -->
        <bean  id="MD5PasswordEncoder"   class="org.jasig.cas.authentication.handler.DefaultPasswordEncoder"   autowire="byName">   
            <constructor-arg  value="MD5"/>
        </bean>
         <bean   id="queryDatabaseAuthenticationHandler"   name="primaryAuthenticationHandler"    class="org.jasig.cas.adaptors.jdbc.QueryDatabaseAuthenticationHandler">  
            <property   name="passwordEncoder"    ref="MD5PasswordEncoder"/>
        </bean>
       <alias   name="dataSource"   alias="queryDatabaseDataSource"/>
       <bean   id="dataSource"
           class="com.mchange.v2.c3p0.ComboPooledDataSource"
           p:driverClass="com.mysql.jdbc.Driver"
           p:jdbcUrl="jdbc:mysql://192.168.103.169:3306/userdb?useUnicode=true&characterEncoding=UTF-8&zeroDateTimeBehavior=convertToNull"
          p:user="root"
          p:password="123"
          p:initialPoolSize="6"
          p:minPoolSize="6"
          p:maxPoolSize="18"
          p:maxIdleTimeExcessConnections="120"
          p:checkoutTimeout="10000"
          p:acquireIncrement="6"
          p:acquireRetryAttempts="5"
          p:acquireRetryDelay="2000"
          p:idleConnectionTestPeriod="30"
          p:preferredTestQuery="select 1"/>
        <!--end  从数据库中的用户表中读取 -->
        
        <alias name="personDirectoryPrincipalResolver" alias="primaryPrincipalResolver" />
    
        <util:map id="attrRepoBackingMap">
            <entry key="uid" value="uid" />
            <entry key="eduPersonAffiliation" value="eduPersonAffiliation" />
            <entry key="groupMembership" value="groupMembership" />
            <entry>
                <key><value>memberOf</value></key>
                <list>
                    <value>faculty</value>
                    <value>staff</value>
                    <value>org</value>
                </list>
            </entry>
        </util:map>
    
        <alias name="serviceThemeResolver" alias="themeResolver" />
    
        <alias name="jsonServiceRegistryDao" alias="serviceRegistryDao" />
    
        <!-- <alias name="defaultTicketRegistry" alias="ticketRegistry" /> -->
        <!-- 票据保存方式及有效期设置 -->
    	<alias name="redisTicketRegistry" alias="ticketRegistry" />
    <!-- 	<bean id="redisTicketRegistry" class="com.hivescm.cas.ticket.registry.RedisTicketRegistry" -->
    <!-- 	    p:client-ref="ticketRedisTemplate" -->
    <!-- 	    p:tgtTimeout="28800" -->
    <!-- 	    p:stTimeout="10"/> -->
    	  <bean id="redisTicketRegistry" class="com.hivescm.cas.ticket.registry.RedisClusterTicketRegistry"
    	    p:client-ref="redisTemplate"
    	    p:tgtTimeout="28800"
    	    p:stTimeout="1000"/>
    	<!-- redis连接池 -->
    <!-- 	<bean id="jedisConnFactory" -->
    <!-- 	      class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory" -->
    <!-- 	      p:hostName="192.168.103.158" -->
    <!-- 	      p:database="10" -->
    <!-- 	      p:usePool="true"/> -->
    	 
    <!-- 	<bean id="ticketRedisTemplate" class="com.hivescm.cas.ticket.registry.TicketRedisTemplate" -->
    <!-- 	      p:connectionFactory-ref="jedisConnFactory"/> -->
    	      
    	      
    	
    
    <!--     jedis 配置 -->
        <bean id="poolConfig" class="redis.clients.jedis.JedisPoolConfig" >
    <!--         最大空闲数 -->
            <property name="maxIdle" value="${redis.maxIdle}" />
    <!--         最大建立连接等待时间 -->
            <property name="maxWaitMillis" value="${redis.maxWait}" />
    <!--         是否在从池中取出连接前进行检验,如果检验失败,则从池中去除连接并尝试取出另一个 -->
            <property name="testOnBorrow" value="${redis.testOnBorrow}" />
        </bean >
    
    <!--     配置文件加载 -->
        <bean id="resourcePropertySource" class="org.springframework.core.io.support.ResourcePropertySource">
            <constructor-arg name="name" value="redis.cluster.properties"/>
            <constructor-arg name="resource" value="classpath:redis.cluster.properties"/>
        </bean>
    <!--     redisCluster配置 -->
        <bean id="redisClusterConfiguration" class="org.springframework.data.redis.connection.RedisClusterConfiguration">
            <constructor-arg name="propertySource" ref="resourcePropertySource"/>
        </bean>
    <!--     redis服务器中心 -->
        <bean id="connectionFactory"  class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory" >
           <constructor-arg name="clusterConfig" ref="redisClusterConfiguration"/>
            <constructor-arg name="poolConfig" ref="poolConfig"/>
            <property name="password" value="${redis.password}" />
            <property name="timeout" value="${redis.timeout}" ></property>
        </bean >
        <bean id="redisTemplate" class="org.springframework.data.redis.core.RedisTemplate" >
            <property name="connectionFactory" ref="connectionFactory" />
    <!--         如果不配置Serializer,那么存储的时候缺省使用String,如果用User类型存储,那么会提示错误User can't cast to String!!  -->
            <property name="keySerializer" >
                <bean class="org.springframework.data.redis.serializer.StringRedisSerializer" />
            </property>
            <property name="valueSerializer" >
                <bean class="org.springframework.data.redis.serializer.JdkSerializationRedisSerializer" />
            </property>
            <property name="hashKeySerializer">
                <bean class="org.springframework.data.redis.serializer.StringRedisSerializer"/>
            </property>
            <property name="hashValueSerializer">
                <bean class="org.springframework.data.redis.serializer.JdkSerializationRedisSerializer"/>
            </property>
        </bean >
        
    
    <!--     <bean id="redisHttpSessionConfiguration" -->
    <!--           class="org.springframework.session.data.redis.config.annotation.web.http.RedisHttpSessionConfiguration"> -->
     <!--        超时时间,默认1800秒 --> 
    <!--         <property name="maxInactiveIntervalInSeconds" value="1800" /> -->
    <!--     </bean> -->
    
    	      
    	      
        
        <alias name="ticketGrantingTicketExpirationPolicy" alias="grantingTicketExpirationPolicy" />
    <!--     <alias name="multiTimeUseOrTimeoutExpirationPolicy" alias="serviceTicketExpirationPolicy" /> -->
        <alias name="neverExpiresExpirationPolicy" alias="serviceTicketExpirationPolicy" />
    
        <alias name="anyAuthenticationPolicy" alias="authenticationPolicy" />
        <alias name="acceptAnyAuthenticationPolicyFactory" alias="authenticationPolicyFactory" />
    
        <bean id="auditTrailManager"
              class="org.jasig.inspektr.audit.support.Slf4jLoggingAuditTrailManager"
              p:entrySeparator="${cas.audit.singleline.separator:|}"
              p:useSingleLine="${cas.audit.singleline:false}"/>
    
        <alias name="neverThrottle" alias="authenticationThrottle" />
    
        <util:list id="monitorsList">
            <ref bean="memoryMonitor" />
            <ref bean="sessionMonitor" />
        </util:list>
    
        <alias name="defaultPrincipalFactory" alias="principalFactory" />
        <alias name="defaultAuthenticationTransactionManager" alias="authenticationTransactionManager" />
        <alias name="defaultPrincipalElectionStrategy" alias="principalElectionStrategy" />
        <alias name="tgcCipherExecutor" alias="defaultCookieCipherExecutor" />
        
        
    </beans>
    

      2.cas.properties 中 打开 cas.jdbc.authn.query.sql=select password  from  t_user  where account=? and  valid=true

  • 相关阅读:
    nodeJS grunt karma+jasmine+require 快速构建前台自动化测试环境搭建
    js闭包
    白鹭 接入vivo小游戏
    白鹭 字节跳动 接入小游戏
    白鹭声音播放问题汇总
    白鹭 有人好奇为什么hashcode 增长的那么快么?都创建了些什么?
    Mac node 安装
    白鹭 修改底层 egret.js 库后再次编译 成 新的库
    js 获取字典长度
    egret 性能优化
  • 原文地址:https://www.cnblogs.com/lvgg/p/7132751.html
Copyright © 2011-2022 走看看