2012-09-08 13 views
5

नहीं मिल रहा है, मुझे एक संदेश के साथ अपवाद प्राप्त होता है: "org.springframework.beans.factory.No.SuchBeanDefinitionException: 'userDetailsService' नामक कोई बीन परिभाषित नहीं किया गया है" भले ही बीन को परिभाषित किया गया हो UserDetailsServiceImpl क्लास में एक सेवा। जैसे:वसंत और वसंत सुरक्षा कॉन्फ़िगरेशन सहायता, एक बीन

@Service(value="userDetailsService") 
public class UserDetailsServiceImpl implements UserDetailsService{ 

मैं नवीनतम वसंत और स्प्रिंग सुरक्षा का उपयोग कर रहा हूँ।

मुझे यकीन नहीं है कि मैं क्या गलत कर रहा हूं। मैं अपनी वसंत एक्सएमएल फाइलों की कॉन्फ़िगरेशन चिपका रहा हूं। Spring-security.xml दिखाता है कि घटक-स्कैन का उपयोग करते समय यह servlet-context.xml से सेम पा सकता है।

धन्यवाद

org.springframework.beans.factory.BeanCreationException: Error creating bean with name org.springframework.security.filterChains': Cannot resolve reference to bean org.springframework.security.web.DefaultSecurityFilterChain#0' while setting bean property sourceList' with key [0]; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name org.springframework.security.web.DefaultSecurityFilterChain#0': Cannot resolve reference to bean org.springframework.security.web.authentication.UsernamePasswordAuthenticationFilter#0' while setting constructor argument with key [2]; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name org.springframework.security.web.authentication.UsernamePasswordAuthenticationFilter#0': Cannot resolve reference to bean org.springframework.security.authentication.ProviderManager#0' while setting bean property authenticationManager'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name org.springframework.security.authentication.ProviderManager#0': Cannot resolve reference to bean 'org.springframework.security.config.authentication.AuthenticationManagerFactoryBean#0' while setting constructor argument; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name org.springframework.security.config.authentication.AuthenticationManagerFactoryBean#0': FactoryBean threw exception on object creation; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name org.springframework.security.authenticationManager': Cannot resolve reference to bean org.springframework.security.authentication.dao.DaoAuthenticationProvider#0' while setting constructor argument with key [0]; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name org.springframework.security.authentication.dao.DaoAuthenticationProvider#0': Cannot resolve reference to bean 'userDetailsService' while setting bean property 'userDetailsService'; nested exception is org.springframework.beans.factory.NoSuchBeanDefinitionException: No bean named 'userDetailsService' is defined 

वसंत-security.xml

<?xml version="1.0" encoding="UTF-8"?> 
<beans:beans xmlns="http://www.springframework.org/schema/security" 
xmlns:beans="http://www.springframework.org/schema/beans" 
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
xsi:schemaLocation="http://www.springframework.org/schema/beans 
     http://www.springframework.org/schema/beans/spring-beans-3.0.xsd 
     http://www.springframework.org/schema/security 
     http://www.springframework.org/schema/security/spring-security-3.1.xsd"> 


<beans:import resource="classpath*:servlet-context.xml"/> 

<global-method-security secured-annotations="enabled"></global-method-security>  

<http auto-config="true" > 
    <!-- Filtering url patterns --> 

    <!-- Anonymous users --> 
    <intercept-url pattern="/" access="IS_AUTHENTICATED_ANONYMOUSLY" /> 
    <intercept-url pattern="/login*" access="IS_AUTHENTICATED_ANONYMOUSLY" /> 

    <!-- Login and logout controls --> 
    <form-login login-page="/login" default-target-url="/profile" 
     authentication-failure-url="/loginfailed" /> 
    <logout invalidate-session="true" logout-success-url="/" 
     delete-cookies="JSESSIONID" /> 

</http> 

<beans:bean id="authenticationProvider" 
    class="org.springframework.security.authentication.dao.DaoAuthenticationProvider"> 
    <beans:property name="userDetailsService" ref="userDetailsService"/> 
</beans:bean> 



<beans:bean id="authenticationManager" 
    class="org.springframework.security.authentication.ProviderManager"> 
    <beans:property name="providers"> 
     <beans:list> 
      <beans:ref local="authenticationProvider" /> 
     </beans:list> 
    </beans:property> 
</beans:bean> 

<authentication-manager> 
    <authentication-provider user-service-ref="userDetailsService"> 
    </authentication-provider> 
</authentication-manager>  

सर्वलेट-context.xml

<?xml version="1.0" encoding="UTF-8"?> 
<beans:beans xmlns="http://www.springframework.org/schema/mvc" 
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
xmlns:beans="http://www.springframework.org/schema/beans" 
xmlns:context="http://www.springframework.org/schema/context" 
xmlns:tx="http://www.springframework.org/schema/tx" 
xsi:schemaLocation="http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd 
    http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd 
    http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd 
    http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd"> 


<annotation-driven /> 

<resources mapping="/resources/**" location="/resources/" /> 

<!-- Resolves views selected for rendering by @Controllers to .jsp resources in the /WEB-INF/views directory --> 
<beans:bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"> 
    <beans:property name="prefix" value="/WEB-INF/views/" /> 
    <beans:property name="suffix" value=".jsp" /> 
</beans:bean> 

               <!-- Data source configuration --> 

<!-- JDBC configuration for ORM --> 
<beans:bean id="dbDataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource"> 
    <beans:property name="driverClassName" value="com.mysql.jdbc.Driver"/> 
    <beans:property name="url" value="jdbc:mysql://localhost:3306/dbName"/> 
    <beans:property name="username" value="root"/> 
    <beans:property name="password" value=""/> 
</beans:bean> 

<!-- Hibernate session Factory --> 
<beans:bean id="sessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean"> 
    <beans:property name="dataSource" ref="dbDataSource" /> 

    <!-- All the model packages with hibernate annotations that need to be scanned. --> 
    <beans:property name="packagesToScan"> 
     <beans:value> 
      com.package.registration.models 
     </beans:value> 
    </beans:property> 

    <!-- Hibernate specific properties --> 
    <beans:property name="hibernateProperties"> 
     <beans:props> 
      <beans:prop key="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</beans:prop> 
      <beans:prop key="hibernate.show_sql">true</beans:prop> 
      <beans:prop key="hibernate.format_sql">true</beans:prop> 
      <beans:prop key="hibernate.hbm2ddl.auto">update</beans:prop> 
      <beans:prop key="org.hibernate.transaction">true</beans:prop> 
     </beans:props> 
    </beans:property> 
</beans:bean> 

<!-- A transaction manager for working with Hibernate SessionFactories --> 
<beans:bean id="transactionManager" class="org.springframework.orm.hibernate4.HibernateTransactionManager"> 
    <beans:property name="sessionFactory" ref="sessionFactory"/> 
</beans:bean> 

<tx:annotation-driven transaction-manager="transactionManager" /> 

<context:component-scan base-package="com.package.app" /> 

+0

शायद उस अपवाद को प्रारूपित करना चाहते हैं, इसलिए हमें दाहिनी तरफ स्क्रॉल करने की आवश्यकता नहीं है। –

उत्तर

7

आपको अपनी अन्य स्प्रिंग कॉन्फ़िगरेशन फ़ाइल में घटक स्कैन करने की आवश्यकता है, न केवल सर्वलेट कॉन्फ़िगरेशन।

वे अलग-अलग संदर्भ हैं, संदर्भ लोडर श्रोता द्वारा लोड किया गया एक, प्रेषक सर्वलेट द्वारा एक।

+0

धन्यवाद, मुझे अभी एहसास हुआ है कि servlet-context.xml डिस्पैचर सर्वलेट विशिष्ट है। इसलिए मैंने वहां से सभी कॉन्फ़िगरेशन हटा दिए और एक नई spring.xml फ़ाइल में डाला। मैंने वेब.एक्सएमएल में कॉन्फिग्लोकेशन संदर्भ में जोड़ा। यह अब काम करता है! – user724535

3

आप

<context:annotation-config /> 
<context:component-scan base-package="<your package name" /> 
आप आवेदन संदर्भ के लिए

जोड़ने सुनिश्चित करें, अन्यथा वसंत जहां सेम एनोटेशन के साथ घोषित देखने के लिए पता नहीं चलेगा। नोट, स्प्रिंग आपके द्वारा निर्दिष्ट पैकेज और सभी सबपैकेज स्कैन करेगा।

संबंधित मुद्दे