2017-07-16 14 views
0

私はSpringセキュリティには新しく、Spring 4にはSpringセキュリティ4で作業しています。開始するには1つのチュートリアルに従いましたが、毎回NoSuchBeanDefinitionエラーが発生しています。 どういうわけか私はウェブとstackoverflowに記載されているようにすべての提案を試みたが、それを把握することができません。Springセキュリティ:NoSuchBean例外エラーを取得する

以下は、Spring-Securityで動作する私のアプリケーションのスニペットです。

ばねのsecurity.xml

<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-4.1.xsd 
http://www.springframework.org/schema/security 
http://www.springframework.org/schema/security/spring-security-4.0.xsd 
http://www.springframework.org/schema/context 
http://www.springframework.org/schema/context/spring-context-3.0.xsd"> 

<!-- enable use-expressions --> 
<http auto-config="true" use-expressions="true"> 
    <intercept-url pattern="/admin**" access="hasRole('ROLE_ADMIN')" /> 

    <!-- access denied page --> 
    <access-denied-handler error-page="/403" /> 
    <form-login 
     login-page="/login" 
     default-target-url="/welcome" 
     authentication-failure-url="/login?error" 
     username-parameter="username" 
     password-parameter="password" /> 
    <logout logout-success-url="/login?logout" /> 
    <!-- enable csrf protection --> 
    <csrf /> 
</http> 

<authentication-manager> 
    <authentication-provider user-service-ref="userDetailsService" > 
     <password-encoder hash="bcrypt" />  
    </authentication-provider> 
</authentication-manager> 

</beans:beans> 


のWeb.xml

<?xml version="1.0" encoding="UTF-8"?> 
<web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee" 
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
xmlns:web="java.sun.com/xml/ns/javaee/web-app_3_0.xsd" 
xsi:schemaLocation="java.sun.com/xml/ns/javaee java.sun.com/xml/ns/javaee /web-app_3_0.xsd" 
> 

<context-param> 
    <param-name>contextConfigLocation</param-name> 
    <param-value>/WEB-INF/spring/appServlet/spring-security.xml </param-value> 
</context-param> 

<!-- Creates the Spring Container shared by all Servlets and Filters --> 
<listener> 
    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> 
</listener> 

<!-- Processes application requests --> 
<servlet> 
    <servlet-name>appServlet</servlet-name> 
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> 
    <init-param> 
     <param-name>contextConfigLocation</param-name> 
     <param-value>/WEB-INF/spring/appServlet/servlet-context.xml, /WEB-INF/spring/appServlet/spring-security.xml</param-value> 
    </init-param> 
    <load-on-startup>1</load-on-startup> 
</servlet> 


<!-- Spring Security --> 
<filter> 
    <filter-name>springSecurityFilterChain</filter-name> 
    <filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class> 
</filter> 
<filter-mapping> 
    <filter-name>springSecurityFilterChain</filter-name> 
    <url-pattern>/*</url-pattern> 
</filter-mapping> 


<servlet-mapping> 
    <servlet-name>appServlet</servlet-name> 
    <url-pattern>/</url-pattern> 
</servlet-mapping> 

<session-config> 
    <tracking-mode>COOKIE</tracking-mode> 
</session-config> 


サーブレットの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.xsd 
http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd 
http://www.springframework.org/schema/context 
http://www.springframework.org/schema/context/spring-context.xsd 
http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.0.xsd"> 

<annotation-driven /> 
<resources mapping="/resources/**" location="/resources/" /> 
<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> 

<!-- Testing Database MySQL Local System -->   
<beans:bean id="dataSource"class="org.apache.commons.dbcp.BasicDataSource" 
    destroy-method="close"> 
    <beans:property name="driverClassName" value="com.mysql.jdbc.Driver" /> 
    <beans:property name="url" value="jdbc:mysql://127.0.0.1:3306/tutorzest" /> 
    <beans:property name="username" value="root" /> 
    <beans:property name="password" value="root" /> 
</beans:bean> 


<!-- Hibernate 4 SessionFactory Bean definition --> 
<beans:bean id="hibernate4AnnotatedSessionFactory" 
    class="org.springframework.orm.hibernate4.LocalSessionFactoryBean"> 
    <beans:property name="dataSource" ref="dataSource" /> 
    <beans:property name="annotatedClasses"> 
     <beans:list> 
      <beans:value>com.spring.model.User</beans:value> 
      <beans:value>com.spring.model.UserRole</beans:value> 
     </beans:list> 
    </beans:property> 
    <beans:property name="hibernateProperties"> 
     <beans:props> 
      <beans:prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect 
      </beans:prop> 
      <beans:prop key="hibernate.show_sql">true</beans:prop> 
     </beans:props> 
    </beans:property> 
</beans:bean> 

<beans:bean id="transactionManager" class="org.springframework.orm.hibernate4.HibernateTransactionManager"> 
    <beans:property name="sessionFactory" ref="hibernate4AnnotatedSessionFactory" /> 
</beans:bean> 


<beans:bean id="userDao" class="com.spring.dao.UserDaoImpl"> 
    <beans:property name="sessionFactory" ref ="hibernate4AnnotatedSessionFactory"/> 
</beans:bean> 

<beans:bean id="userDetailsService" class="com.spring.service.MyUserDetailsService"> 
</beans:bean> 

<context:component-scan base-package="com.spring.controller" /> 
<tx:annotation-driven transaction-manager="transactionManager"/> 

</beans:beans> 

** MyUserDetailsS​​ervice **

@Service("userDetailsService") 
public class MyUserDetailsService implements UserDetailsService { 

//get user from the database, via Hibernate 
@Autowired 
private UserDao userDao; 

@Transactional(readOnly=true) 
@Override 
public UserDetails loadUserByUsername(final String username) 
    throws UsernameNotFoundException { 

    com.xpedia.spring.model.User user = userDao.findByUserName(username); 
    List<GrantedAuthority> authorities = 
            buildUserAuthority(user.getUserRole()); 

    return buildUserForAuthentication(user, authorities); 

} 

// Converts com.mkyong.users.model.User user to 
// org.springframework.security.core.userdetails.User 
private User buildUserForAuthentication(com.xpedia.spring.model.User user, 
    List<GrantedAuthority> authorities) { 
    return new User(user.getUsername(), user.getPassword(), 
     user.isEnabled(), true, true, true, authorities); 
} 

private List<GrantedAuthority> buildUserAuthority(Set<UserRole> userRoles) 

    Set<GrantedAuthority> setAuths = new HashSet<GrantedAuthority>(); 

    // Build user's authorities 
    for (UserRole userRole : userRoles) { 
     setAuths.add(new SimpleGrantedAuthority(userRole.getRole())); 
    } 

    List<GrantedAuthority> Result = 
    new ArrayList <GrantedAuthority> (setAuths); 

    return Result; 
} 

} 


私は、次のエラー取得しています実行した後:

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' '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

xml構成の一部が欠落している可能性があります。しかし、私はそれを理解しようと多くの試みの後にそれが難しいと思っています。これで私を助けてください。あなたはservlet-context.xml

<context:component-scan base-package="com.sparkle" /> 
<mvc:annotation-driven /> 

<bean id="userDetailsService" 
    class="com.spring.service.MyUserDetailsService"> 
+0

あなたのセキュリティ設定は、ルートアプリケーションコンテキストです。ルート/親コンテキストの子コンテキストからUserSetailServiceを参照しています。子は親コンテキストBeanを参照できますが、他の方法では動作しません。この問題を解決する1つの方法は、サーブレットコンテキストでのみコントローラをスキャンし、ルートコンテキストでコントローラ以外のすべてをスキャンすることです。 –

+0

また、Dispatcherサーブレットのinit paramからセキュリティコンテキストを削除します。 –

答えて

1

に怒鳴るのコードを追加する必要が

+0

@Ivanありがとうございました。あなたの提案はうまくいきました。 – anand

-1

はこれを変更します。

<context-param> 
    <param-name>contextConfigLocation</param-name> 
    <param-value>/WEB-INF/spring/appServlet/spring-security.xml </param-value> 
</context-param> 

<!-- Creates the Spring Container shared by all Servlets and Filters --> 
<listener> 
    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> 
</listener> 

<!-- Processes application requests --> 
<servlet> 
    <servlet-name>appServlet</servlet-name> 
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> 
    <init-param> 
     <param-name>contextConfigLocation</param-name> 
     <param-value>/WEB-INF/spring/appServlet/servlet-context.xml, /WEB-INF/spring/appServlet/spring-security.xml</param-value> 
    </init-param> 
    <load-on-startup>1</load-on-startup> 
</servlet> 

へ:他の子コンテキストであるのに対し、

<context-param> 
     <param-name>contextConfigLocation</param-name> 
     <param-value> 
      /WEB-INF/spring/appServlet/servlet-context.xml 
      /WEB-INF/spring/appServlet/spring-security.xml 
     </param-value> 
    </context-param> 
    <listener> 
     <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> 
    </listener> 
    <servlet> 
     <servlet-name>appServlet</servlet-name> 
     <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> 
     <load-on-startup>1</load-on-startup> 
    </servlet> 
+0

これがなぜ機能するのか説明するのは難しいですか? –

関連する問題