Wie verwende ich benutzerdefinierte Rollen/Behörden in Spring Security?

Während der Migration einer legacy-Anwendung auf spring security bekam ich die folgende Ausnahme:

org.springframework.beans.factory.BeanCreationException: Error creating bean with name '_filterChainProxy': Initialization of bean failed; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name '_filterChainList': Cannot resolve reference to bean '_filterSecurityInterceptor' while setting bean property 'filters' with key [3]; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name '_filterSecurityInterceptor': Invocation of init method failed; nested exception is java.lang.IllegalArgumentException: Unsupported configuration attributes: [superadmin]
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:480)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory$1.run(AbstractAutowireCapableBeanFactory.java:409)
at java.security.AccessController.doPrivileged(Native Method)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:380)
at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:264)

In der alten Applikation, gibt es Rollen wie "superadmin", "editor", "helpdesk" etc. Aber in allen Spring Security-Beispiele sehe ich nur Rollen wie "ROLE_" ("ROLE_ADMIN" etc). Wenn ich umbenennen "superadmin" , "ROLE_ADMIN" und verwenden Sie nur diese Rolle in der config funktioniert alles.

Nicht funktioniert:

 <http auto-config="true">                                      
    <intercept-url pattern="/restricted/**" access="superadmin"/>
    <form-login
        authentication-failure-url="/secure/loginAdmin.do?error=true"
        login-page="/secure/loginAdmin.do" />        
</http> 

Funktioniert:

<http auto-config="true">                                      
    <intercept-url pattern="/restricted/**" access="ROLE_ADMIN"/>
    <form-login
        authentication-failure-url="/secure/loginAdmin.do?error=true"
        login-page="/secure/loginAdmin.do" />        
</http> 

Ist möglich, verwenden Sie benutzerdefinierte Rollen-Namen?

InformationsquelleAutor der Frage D. Wroblewski | 2009-06-12

Schreibe einen Kommentar