123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145 |
- <?xml version="1.0" encoding="UTF-8"?>
- <!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.org/dtd/spring-beans.dtd">
- <!--
- - A simple "base bones" Acegi Security configuration.
- -
- - The sample includes the "popular" features that people tend to use.
- - Specifically, form authentication, remember-me, and anonymous processing.
- - Other features aren't setup, as these can be added later by inserting
- - the relevant XML fragments as specified in the Reference Guide.
- -
- - To assist new users, the filters specified in the FilterChainProxy are
- - declared in the application context in the same order. Collaborators
- - required by those filters are placed at the end of the file.
- -
- - $Id$
- -->
- <beans>
- <bean id="filterChainProxy" class="org.springframework.security.util.FilterChainProxy">
- <property name="filterInvocationDefinitionSource">
- <value><![CDATA[
- CONVERT_URL_TO_LOWERCASE_BEFORE_COMPARISON
- PATTERN_TYPE_APACHE_ANT
- /**=httpSessionContextIntegrationFilter,logoutFilter,authenticationProcessingFilter,basicProcessingFilter,securityContextHolderAwareRequestFilter,rememberMeProcessingFilter,anonymousProcessingFilter,exceptionTranslationFilter,filterInvocationInterceptor
- ]]></value>
- </property>
- </bean>
- <bean id="httpSessionContextIntegrationFilter" class="org.springframework.security.context.HttpSessionContextIntegrationFilter"/>
- <bean id="logoutFilter" class="org.springframework.security.ui.logout.LogoutFilter">
- <constructor-arg value="/index.jsp"/> <!-- URL redirected to after logout -->
- <constructor-arg>
- <list>
- <ref bean="rememberMeServices"/>
- <bean class="org.springframework.security.ui.logout.SecurityContextLogoutHandler"/>
- </list>
- </constructor-arg>
- </bean>
- <bean id="authenticationProcessingFilter" class="org.springframework.security.ui.webapp.AuthenticationProcessingFilter">
- <property name="authenticationManager" ref="authenticationManager"/>
- <property name="authenticationFailureUrl" value="/acegilogin.jsp?login_error=1"/>
- <property name="defaultTargetUrl" value="/"/>
- <property name="filterProcessesUrl" value="/j_spring_security_check"/>
- <property name="rememberMeServices" ref="rememberMeServices"/>
- </bean>
- <bean id="basicProcessingFilter" class="org.springframework.security.ui.basicauth.BasicProcessingFilter">
- <property name="authenticationManager"><ref local="authenticationManager"/></property>
- <property name="authenticationEntryPoint"><ref local="basicProcessingFilterEntryPoint"/></property>
- </bean>
- <bean id="basicProcessingFilterEntryPoint" class="org.springframework.security.ui.basicauth.BasicProcessingFilterEntryPoint">
- <property name="realmName"><value>My Realm</value></property>
- </bean>
- <bean id="securityContextHolderAwareRequestFilter" class="org.springframework.security.wrapper.SecurityContextHolderAwareRequestFilter"/>
- <bean id="rememberMeProcessingFilter" class="org.springframework.security.ui.rememberme.RememberMeProcessingFilter">
- <property name="authenticationManager" ref="authenticationManager"/>
- <property name="rememberMeServices" ref="rememberMeServices"/>
- </bean>
- <bean id="anonymousProcessingFilter" class="org.springframework.security.providers.anonymous.AnonymousProcessingFilter">
- <property name="key" value="changeThis"/>
- <property name="userAttribute" value="anonymousUser,ROLE_ANONYMOUS"/>
- </bean>
- <bean id="exceptionTranslationFilter" class="org.springframework.security.ui.ExceptionTranslationFilter">
- <property name="authenticationEntryPoint">
- <bean class="org.springframework.security.ui.webapp.AuthenticationProcessingFilterEntryPoint">
- <property name="loginFormUrl" value="/acegilogin.jsp"/>
- <property name="forceHttps" value="false"/>
- </bean>
- </property>
- <property name="accessDeniedHandler">
- <bean class="org.springframework.security.ui.AccessDeniedHandlerImpl">
- <property name="errorPage" value="/accessDenied.jsp"/>
- </bean>
- </property>
- </bean>
- <bean id="filterInvocationInterceptor" class="org.springframework.security.intercept.web.FilterSecurityInterceptor">
- <property name="authenticationManager" ref="authenticationManager"/>
- <property name="accessDecisionManager">
- <bean class="org.springframework.security.vote.AffirmativeBased">
- <property name="allowIfAllAbstainDecisions" value="false"/>
- <property name="decisionVoters">
- <list>
- <bean class="org.springframework.security.vote.RoleVoter"/>
- <bean class="org.springframework.security.vote.AuthenticatedVoter"/>
- </list>
- </property>
- </bean>
- </property>
- <property name="objectDefinitionSource">
- <value><![CDATA[
- CONVERT_URL_TO_LOWERCASE_BEFORE_COMPARISON
- PATTERN_TYPE_APACHE_ANT
- /secure/extreme/**=ROLE_SUPERVISOR
- /secure/**=IS_AUTHENTICATED_REMEMBERED
- /**=IS_AUTHENTICATED_ANONYMOUSLY
- ]]></value>
- </property>
- </bean>
- <bean id="rememberMeServices" class="org.springframework.security.ui.rememberme.TokenBasedRememberMeServices">
- <property name="userDetailsService" ref="userDetailsService"/>
- <property name="key" value="changeThis"/>
- </bean>
- <bean id="authenticationManager" class="org.springframework.security.providers.ProviderManager">
- <property name="providers">
- <list>
- <ref local="daoAuthenticationProvider"/>
- <bean class="org.springframework.security.providers.anonymous.AnonymousAuthenticationProvider">
- <property name="key" value="changeThis"/>
- </bean>
- <bean class="org.springframework.security.providers.rememberme.RememberMeAuthenticationProvider">
- <property name="key" value="changeThis"/>
- </bean>
- </list>
- </property>
- </bean>
- <bean id="daoAuthenticationProvider" class="org.springframework.security.providers.dao.DaoAuthenticationProvider">
- <property name="userDetailsService" ref="userDetailsService"/>
- </bean>
- <!-- UserDetailsService is the most commonly frequently Acegi Security interface implemented by end users -->
- <bean id="userDetailsService" class="org.springframework.security.userdetails.memory.InMemoryDaoImpl">
- <property name="userProperties">
- <bean class="org.springframework.beans.factory.config.PropertiesFactoryBean">
- <property name="location" value="/WEB-INF/users.properties"/>
- </bean>
- </property>
- </bean>
- <!-- This bean is optional; it isn't used by any other bean as it only listens and logs -->
- <bean id="loggerListener" class="org.springframework.security.event.authentication.LoggerListener"/>
- </beans>
|