与userDetailsS​​ervice冲突的bean

时间:2015-01-19 15:11:21

标签: spring spring-mvc spring-security

我正在开发一个带有spring-security的Spring-MVC应用程序,我有2种不同类型的用户可以登录,一个来自个人帐户,一个是组帐户。 所以基本上我想要2个daoAuthenticationMethods。 我已经实现了UserDetails和userDetailsS​​ervice接口。在提到this上的帖子后,我正试图实施这种方法。 我得到的错误是服务层中的userDetailsS​​ervice冲突。我知道我不能使用2个userDetailsS​​ervice,但如果我在xml的属性选项卡中添加了其他内容,则会出现未知属性错误。请检查配置,并告诉我我可能做错了什么。

错误日志:

Offending resource: ServletContext resource [/WEB-INF/spring/appServlet/security-applicationContext.xml]; nested exception is org.springframework.beans.factory.BeanDefinitionStoreException: Unexpected exception parsing XML document from ServletContext resource [/WEB-INF/spring/appServlet/servlet-context.xml]; nested exception is org.springframework.context.annotation.ConflictingBeanDefinitionException: Annotation-specified bean name 'userDetailsService' for bean class [com.journaldev.spring.service.GroupLoginServiceImpl] conflicts with existing, non-compatible bean definition of same name and class [com.journaldev.spring.service.LoginServiceImpl]
    at org.springframework.beans.factory.parsing.FailFastProblemReporter.error(FailFastProblemReporter.java:70)
    at org.springframework.beans.factory.parsing.ReaderContext.error(ReaderContext.java:85)

Security-application-context.xml:

<!-- Global Security settings -->
<security:global-method-security pre-post-annotations="enabled" />
<security:http create-session="ifRequired" use-expressions="true" auto-config="true" disable-url-rewriting="true">
    <security:form-login login-page="/" default-target-url="/canvas/list"
                         always-use-default-target="false"  authentication-failure-url="/denied.jsp" />

<bean id="springSecurityFilterChain" class="org.springframework.security.web.FilterChainProxy">
    <security:filter-chain-map path-type="ant">
        <security:filter-chain pattern="/**" filters="authenticationProcessingFilterForPersonal, authenticationProcessingFilterForGroup"/>
    </security:filter-chain-map>
</bean>

<bean id="authenticationProcessingFilterForPersonal"
      class="org.springframework.security.web.authentication.UsernamePasswordAuthenticationFilter">
    <property name="authenticationManager" ref="authenticationManagerForPersonal"/>
    <property name="filterProcessesUrl" value="/j_spring_security_check_for_person" />

</bean>

<bean id="authenticationProcessingFilterForGroup"
      class="org.springframework.security.web.authentication.UsernamePasswordAuthenticationFilter">
    <property name="authenticationManager" ref="authenticationManagerForGroup"/>
    <property name="filterProcessesUrl" value="/j_spring_security_check_for_group"/>
</bean>


<bean id="authenticationManagerForPersonal" class="org.springframework.security.authentication.ProviderManager">

<property name="providers">
        <list>
            <bean class="org.springframework.security.authentication.dao.DaoAuthenticationProvider">
                <property name="userDetailsService">
                    <ref bean="LoginServiceImpl"/>
                </property>
                <property name="passwordEncoder" ref="encoder"/>
            </bean>
        </list>
    </property>
</bean>

<bean id="authenticationManagerForGroup" class="org.springframework.security.authentication.ProviderManager">
    <property name="providers">
        <list>
            <bean class="org.springframework.security.authentication.dao.DaoAuthenticationProvider">
                <property name="userDetailsService">
                    <ref bean="GroupLoginServiceImpl"/>
                </property>
                <property name="passwordEncoder" ref="encoder"/>
            </bean>
        </list>
    </property>
</bean>


<security:authentication-manager alias="authenticationManager">
    <security:authentication-provider ref="authenticationManagerForPersonal"/>
    <security:authentication-provider ref="authenticationManagerForGroup"/>
</security:authentication-manager>

<beans:bean id="encoder"
            class="org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder">
    <beans:constructor-arg name="strength" value="11" />
</beans:bean>

LoginServiceImpl:

// This method is for the personalAccount
@Transactional
@Service("userDetailsService")
public class LoginServiceImpl implements UserDetailsService{

    @Autowired private PersonDAO personDAO;
    @Autowired private Assembler assembler;

    private static final GrantedAuthority USER_AUTH = new SimpleGrantedAuthority("ROLE_USER");

    @Override
    public UserDetails loadUserByUsername(String username) throws UsernameNotFoundException,DataAccessException {
        Person person = personDAO.findPersonByUsername(username.toLowerCase());
            if(person == null) { throw new UsernameNotFoundException("Wrong username or password");} 
        return assembler.buildUserFromUserEntity(person);
    }
}

GroupLoginServiceImpl:

@Transactional
@Service("userDetailsService")  // I cannot change this, it throws me error when I change this or remove this
public class GroupLoginServiceImpl implements UserDetailsService {

    @Autowired
    private GroupMembersDAO groupMembersDAO;

    @Autowired
    private GroupAssembler groupAssembler;

    private static final GrantedAuthority USER_AUTH = new SimpleGrantedAuthority("ROLE_GROUP");

    @Override
    public UserDetails loadUserByUsername(String username) throws UsernameNotFoundException,DataAccessException {
        GroupMembers groupMembers = groupMembersDAO.findMemberByUsername(username.toLowerCase());
        if(groupMembers == null) { throw new UsernameNotFoundException("Wrong username or password");} 
        return groupAssembler.buildUserFromUserEntity(groupMembers);
    }
}

如有必要,我也可以发布任何其他方法。请让我知道该怎么做。任何指针都是受欢迎的。谢谢。

1 个答案:

答案 0 :(得分:1)

我认为您误解了如何编写XML。第一个例子应该是:

<property name="userDetailsService" ref="userDetailsService">

第二个:

<property name="userDetailsService" ref="groupDetailsService">