2 changed files with 78 additions and 0 deletions
@ -0,0 +1,26 @@
@@ -0,0 +1,26 @@
|
||||
package org.springframework.security.integration; |
||||
|
||||
import org.junit.Test; |
||||
import org.junit.runner.RunWith; |
||||
import org.springframework.beans.factory.annotation.Autowired; |
||||
import org.springframework.security.AccessDeniedException; |
||||
import org.springframework.security.concurrent.SessionRegistry; |
||||
import org.springframework.security.context.SecurityContextHolder; |
||||
import org.springframework.security.providers.UsernamePasswordAuthenticationToken; |
||||
import org.springframework.test.context.ContextConfiguration; |
||||
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner; |
||||
|
||||
@ContextConfiguration(locations={"/sec-936-app-context.xml"}) |
||||
@RunWith(SpringJUnit4ClassRunner.class) |
||||
public class SEC936ApplicationContextTests { |
||||
@Autowired |
||||
/** SessionRegistry is used as the test service interface (nothing to do with the test) */ |
||||
private SessionRegistry sessionRegistry; |
||||
|
||||
@Test(expected=AccessDeniedException.class) |
||||
public void securityInterceptorHandlesCallWithNoTargetObject() { |
||||
SecurityContextHolder.getContext().setAuthentication(new UsernamePasswordAuthenticationToken("bob","bobspassword")); |
||||
sessionRegistry.getAllPrincipals(); |
||||
} |
||||
|
||||
} |
||||
@ -0,0 +1,52 @@
@@ -0,0 +1,52 @@
|
||||
<beans xmlns="http://www.springframework.org/schema/beans" |
||||
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" |
||||
xmlns:util="http://www.springframework.org/schema/util" |
||||
xmlns:security="http://www.springframework.org/schema/security" |
||||
xsi:schemaLocation=" |
||||
http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd |
||||
http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-2.5.xsd |
||||
http://www.springframework.org/schema/security http://www.springframework.org/schema/security/spring-security-2.0.2.xsd"> |
||||
|
||||
<security:authentication-provider> |
||||
<security:user-service> |
||||
<security:user name="bob" password="bobspassword" authorities="ROLE_A,ROLE_B"/> |
||||
</security:user-service> |
||||
</security:authentication-provider> |
||||
|
||||
<security:authentication-manager alias="authenticationManager"/> |
||||
|
||||
<bean id="accessDecisionManager" class="org.springframework.security.vote.AffirmativeBased"> |
||||
<property name="allowIfAllAbstainDecisions" value="false"/> |
||||
<property name="decisionVoters"> |
||||
<util:list> |
||||
<bean class="org.springframework.security.vote.RoleVoter" /> |
||||
<bean class="org.springframework.security.vote.AuthenticatedVoter" /> |
||||
</util:list> |
||||
</property> |
||||
</bean> |
||||
|
||||
<bean id="securityInterceptor" class="org.springframework.security.intercept.method.aopalliance.MethodSecurityInterceptor"> |
||||
<property name="validateConfigAttributes" value="true"/> |
||||
<property name="rejectPublicInvocations" value="true"/> |
||||
<property name="authenticationManager" ref="authenticationManager"/> |
||||
<property name="accessDecisionManager" ref="accessDecisionManager"/> |
||||
<property name="objectDefinitionSource"><value> |
||||
org.springframework.security.concurrent.SessionRegistry.get*=ROLE_C |
||||
</value></property> |
||||
</bean> |
||||
|
||||
<bean id="httpRemoteService" class="org.springframework.aop.framework.ProxyFactoryBean"> |
||||
<property name="proxyInterfaces" value="org.springframework.security.concurrent.SessionRegistry"/> |
||||
<property name="interceptorNames"> |
||||
<list> |
||||
<value>securityInterceptor</value> |
||||
<value>httpInvokerClientInterceptor</value> |
||||
</list> |
||||
</property> |
||||
</bean> |
||||
|
||||
<bean id="httpInvokerClientInterceptor" class="org.springframework.remoting.httpinvoker.HttpInvokerClientInterceptor"> |
||||
<property name="serviceUrl" value="http://somehost/someUrl"/> |
||||
</bean> |
||||
|
||||
</beans> |
||||
Loading…
Reference in new issue