我知道@Component在Spring 2.5中引入了注释,以便通过使用类路径扫描来消除xml bean的定义.
@Bean是在3.0版本中引入的,可以用来@Configuration完全摆脱xml文件并使用java配置.
是否可以重复使用@Component注释而不是引入@Bean注释?我的理解是,最终目标是在两种情况下都创建bean.
为什么我不能@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相同的东西?
是否使用@Autowired自动检测?使用@Qualifier时是按名称依赖注入吗?我们如何使用这些注释进行setter和构造函数注入?
为什么这样做:
@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)
谢谢!
是否存在可以提升多个限定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)