将基于注释的Bean注入基于xml的bean

时间:2015-05-07 11:58:56

标签: spring spring-data spring-ioc

我的持久性配置类看起来像吼叫:

@Configuration
@EnableTransactionManagement
public class PersistenceConfig {

    @Autowired
    private Environment env;

    // code here

    @Bean(name = "dataSource")
    public DataSource dataSource()
    {
        System.out.println("------------------------datasource----------------------");
        BasicDataSource dataSource = new BasicDataSource();
        dataSource.setDriverClassName(env.getProperty("jdbc.driverClassName"));
        dataSource.setUrl(env.getProperty("jdbc.url"));
        dataSource.setUsername(env.getProperty("jdbc.username"));
        dataSource.setPassword(env.getProperty("jdbc.password"));
        return dataSource;
    }


}

我有一个xml配置类:

<?xml version="1.0" encoding="UTF-8" ?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:oauth="http://www.springframework.org/schema/security/oauth2"
       xmlns:context="http://www.springframework.org/schema/context"
       xmlns:sec="http://www.springframework.org/schema/security" xmlns:mvc="http://www.springframework.org/schema/mvc"
       xsi:schemaLocation="http://www.springframework.org/schema/security/oauth2 http://www.springframework.org/schema/security/spring-security-oauth2-2.0.xsd
  http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd
  http://www.springframework.org/schema/security http://www.springframework.org/schema/security/spring-security-3.2.xsd
  http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.1.xsd
  http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.1.xsd ">

<authentication-manager alias="authenticationManager"
                            xmlns="http://www.springframework.org/schema/security">
     <authentication-provider>

        <user-service>
            <user name="username" password="password" authorities="USER_ROLE" />
        </user-service>


        <jdbc-user-service data-source-ref="dataSource"
                               users-by-username-query="query here"
                               authorities-by-username-query="query here" />

    </authentication-provider>
</authentication-manager>
<!-- code here -->

所以我想在<jdbc-user-service data-source-ref="dataSource" ... >中注入名为“ dataSource ”的bean,注释为 @Bean (在持久化配置类中),我该怎么办?做到了吗?

3 个答案:

答案 0 :(得分:0)

试试这个:

<bean class="PersistenceConfig.class"/>
你的xml配置中的

提示:确保您拥有此后处理器

<bean class="org.springframework.config.java.process.ConfigurationPostProcessor"/>

答案 1 :(得分:0)

这种情况正在发生,因为您正在PersistenceConfig类之前加载xml配置,该类正在创建&#34; dataSource&#34;豆。首先加载类,然后加载xml配置。

<?xml version="1.0" encoding="UTF-8" ?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:oauth="http://www.springframework.org/schema/security/oauth2"
       xmlns:context="http://www.springframework.org/schema/context"
       xmlns:sec="http://www.springframework.org/schema/security" xmlns:mvc="http://www.springframework.org/schema/mvc"
       xsi:schemaLocation="http://www.springframework.org/schema/security/oauth2 http://www.springframework.org/schema/security/spring-security-oauth2-2.0.xsd
  http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd
  http://www.springframework.org/schema/security http://www.springframework.org/schema/security/spring-security-3.2.xsd
  http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.1.xsd
  http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.1.xsd ">
  <context:component-scan base-package="your_package.PersistenceConfig" /> 
    <context:annotation-config /><mvc:annotation-driven/> 
<authentication-manager alias="authenticationManager"
                            xmlns="http://www.springframework.org/schema/security">
     <authentication-provider>

        <user-service>
            <user name="username" password="password" authorities="USER_ROLE" />
        </user-service>


        <jdbc-user-service data-source-ref="dataSource"
                               users-by-username-query="query here"
                               authorities-by-username-query="query here" />

    </authentication-provider>
</authentication-manager>
<!-- code here -->

答案 2 :(得分:0)

我通过更改配置文件的加载顺序使其工作,以便Spring加载包含以下内容的配置文件:

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

在我的webSecurityConfig.xml(上面的配置文件)之前

<context-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>
            WEB-INF/mvc-servlet.xml
            classpath:webSecurityConfig.xml
        </param-value>
</context-param>