相关疑难解决方法(0)

Spring:@Component与@Bean

我知道@Component在Spring 2.5中引入了注释,以便通过使用类路径扫描来消除xml bean的定义.

@Bean是在3.0版本中引入的,可以用来@Configuration完全摆脱xml文件并使用java配置.

是否可以重复使用@Component注释而不是引入@Bean注释?我的理解是,最终目标是在两种情况下都创建bean.

java spring annotations autowired

387
推荐指数
14
解决办法
21万
查看次数

@Bean和@Autowired之间的区别

为什么我不能@Autowired在这种情况下使用?

@SpringBootApplication
public class Application {

    @Autowired
    BookingService bookingService;

    public static void main(String[] args) {
        bookingService.book("Alice", "Bob", "Carol");
    }
}
Run Code Online (Sandbox Code Playgroud)

但可以使用 @Bean

@SpringBootApplication
public class Application {

    @Bean
    BookingService bookingService() {
        return new BookingService();
    }

    public static void main(String[] args) {
        ApplicationContext ctx = SpringApplication.run(Application.class, args);
        BookingService bookingService = ctx.getBean(BookingService.class);
        bookingService.book("Alice", "Bob", "Carol");
    }
}
Run Code Online (Sandbox Code Playgroud)

是不是两种方式生成BookingService相同的东西?

java spring dependency-injection

56
推荐指数
4
解决办法
4万
查看次数

Spring @Autowired和@Qualifier

是否使用@Autowired自动检测?使用@Qualifier时是按名称依赖注入吗?我们如何使用这些注释进行setter和构造函数注入?

java spring

34
推荐指数
3
解决办法
7万
查看次数

为什么我在Spring配置类中不需要@Autowired @Bean方法?

为什么这样做:

@Configuration
public class MyConfig {

  @Bean
  public A getA() {
    return new A();
  }

  @Bean                 <-- Shouldn't I need @Autowired here?
  public B getB(A a) {
    return new B(a);
  }  
}
Run Code Online (Sandbox Code Playgroud)

谢谢!

java spring dependency-injection

9
推荐指数
2
解决办法
6086
查看次数

Spring XML相当于@Primary

是否存在可以提升多个限定bean之一的@Primary的XML等价物

示例场景:

我有一个启动了自动配置的spring-boot应用程序.我已经定义了多个数据源,但是spring无法选择其中一个数据源作为默认值.

org.springframework.beans.factory.NoUniqueBeanDefinitionException: No qualifying bean of type [javax.sql.DataSource] is defined: expected single matching bean but found 2: mysqlDataSource,oracleDataSource
Run Code Online (Sandbox Code Playgroud)

datasources.xml

 <?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:jdbc="http://www.springframework.org/schema/jdbc"
    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.xsd
        http://www.springframework.org/schema/jdbc
        http://www.springframework.org/schema/jdbc/spring-jdbc.xsd">

    <bean id="mysqlDataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
        <property name="driverClassName" value="com.mysql.jdbc.Driver" />
        <property name="url" value="jdbc:mysql://localhost:3306/mcs" />
        <property name="username" value="root" />
        <property name="password" value="root" />
    </bean>


    <bean id="oracleDataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
        <property name="driverClassName" value="oracle.jdbc.driver.OracleDriver" />
        <property name="url" value="jdbc:oracle:thin:@localhost:1521:test" />
        <property name="username" value="scott" />
        <property name="password" value="tiger" />
    </bean>

    <bean id="transactionManager"
    class="org.springframework.batch.support.transaction.ResourcelessTransactionManager" />

</beans>
Run Code Online (Sandbox Code Playgroud)

java xml spring

6
推荐指数
1
解决办法
5953
查看次数