Spring-security - AccessDecisionVoter-impl не будет вызываться - PullRequest
4 голосов
/ 13 марта 2011


Я пытаюсь создать пользовательский AccessDecisionVoter и просто остановить его в отлаженном при его вызове.

Я установил точку останова в каждом методе, но ничего не произошло.

spring-security.xml:

<bean id="accessDecisionManager" class="org.springframework.security.access.vote.UnanimousBased">
  <property name="decisionVoters">
     <list>
          <bean class="com.affiliates.server.security.voters.VoterTest">
              <property name="brandsApi"  ref="brandsApi"/>
          </bean>
        </list>
  </property>

IBrandsApi.java

    public interface IBrandsApi {

    IHibernateBean getByPK(Integer id);

    @Secured({ "ROLE_BRAND_ADMIN" })    
    IHibernateBean update(IHibernateBean brand);

    @Secured({ "ROLE_BRAND_ADMIN" })    
    IHibernateBean insert(IHibernateBean brand);

    @Secured({ "ROLE_BRAND_ADMIN" })    
    ResultContainer getAll(IFilter filter);

    @Secured({ "ROLE_ADMIN" })  
    Integer delete(IFilter filter); 
}

VoterTest.java (пустой файл с точками останова)

    public class VoterTest implements AccessDecisionVoter {
private IBrandsApi brandsApi;

    public IBrandsApi getBrandsApi() {
        return brandsApi;
    }

    public void setBrandsApi(IBrandsApi brandsApi) {
        this.brandsApi = brandsApi;
    }

        @Override
        public boolean supports(ConfigAttribute attribute) {
            System.out.println("here");
            return false;

        }

        @Override
        public boolean supports(Class<?> clazz) {
            System.out.println("here");
            return false;
        }

        @Override
        public int vote(Authentication authentication, Object object,
                Collection<ConfigAttribute> attributes) {
            System.out.println("here");
            return 0;
        }
    }

Кстати, не было никаких исключений при загрузке / запуске приложения. Спасибо

1 Ответ

6 голосов
/ 13 марта 2011

Вам необходимо использовать свой собственный AccessDecisionManager, в противном случае используется стандартный.Вы можете сделать это с помощью

<global-method-security access-decision-manager-ref="accessDecisionManager"/>

Для получения дополнительной информации об этом посмотрите документацию .

Еще одна вещь: supports() методы в вашем избирателедолжно, вероятно, вернуть true, иначе vote() не будет вызвано.

...