Spring註解開發之自動裝配
阿新 • • 發佈:2018-12-19
自動裝配:Spring利用依賴注入(DI),完成對IOC容器中中各個元件的依賴關係賦值;
自動裝配[email protected]&@Qualifier&@Primary
使用@Autowire
註解可以為SpringBean物件自動注入物件
BookDao:
@Repository
public class BookDao {
private String lable = "1";
public String getLable() {
return lable;
}
public void setLable(String lable) {
this .lable = lable;
}
@Override
public String toString() {
return "BookDao [lable=" + lable + "]";
}
}
@Service
public class BookService {
@Autowired
private BookDao bookDao;
public void print(){
System.out.println(bookDao);
}
@Override
public String toString() {
return "BookService [bookDao=" + bookDao + "]";
}
}
@AutoWire
:
- 預設優先按照型別去容器中找對應的元件:applicationContext.getBean(BookDao.class);找到就賦值
- 如果找到多個相同型別的元件,再將屬性的名稱作為元件的id去容器中查詢:applicationContext.getBean(“bookDao”)
- @Qualifier(“bookDao”):使用@Qualifier指定需要裝配的元件的id,而不是使用屬性名
public class BookService {
@Qualifier("bookDao")
@Autowired
private BookDao bookDao;
- 使用了
@Autowire
一定要將屬性賦值好,否則會報錯,即Spring容器中一定要要相應的Bean
public class BookService {
@Autowired(required=false)
private BookDao bookDao;
@Primary
:讓Spring進行自動裝配的時候,預設使用首選的bean,也可以繼續使用@Qualifier
指定需要裝配的bean的名字
@Primary
@Bean("bookDao2") // 如果只是用@Autowire注入的話,會優先使用哪個該Bean
public BookDao bookDao(){
BookDao bookDao = new BookDao();
bookDao.setLable("2");
return bookDao;
}
自動裝配[email protected]&@Inject
Spring還支援使用@Resource(JSR250)和@Inject(JSR330)[java規範的註解]
@Resource
: 可以和@Autowired
一樣實現自動裝配功能;預設是按照元件名稱進行裝配的;但不支援@Primary功能也不支援類似@Autowired(reqiured=false)
;
public class BookService {
@Resource(name="bookDao2")
private BookDao bookDao;
@Inject
:需要匯入javax.inject的包,和Autowired的功能一樣。沒有required=false的功能;
public class BookService {
@Inject
private BookDao bookDao;
自動裝配-方法、構造器位置的自動裝配.
- [標註在方法位置]:@Bean+方法引數;引數從容器中獲取;預設不寫@Autowired效果是一樣的;都能自動裝配
@Component
public class Boss {
private Car car;
public Car getCar() {
return car;
}
@Autowired
//標註在方法,Spring容器建立當前物件,就會呼叫該方法,完成賦值;
//方法使用的引數,自定義型別的值從ioc容器中獲取
public void setCar(Car car) {
this.car = car;
}
- [標在構造器上]:如果元件只有一個有參構造器,這個有參構造器的@Autowired可以省略,引數位置的元件還是可以自動從容器中獲取
//預設加在ioc容器中的元件,容器啟動會呼叫無參構造器建立物件,再進行初始化賦值等操作
@Component
public class Boss {
private Car car;
//構造器要用的元件,都是從容器中獲取
@Autowired // 可以省略
public Boss(Car car){
this.car = car;
System.out.println("Boss...有參構造器");
}
- 放在引數位置
public class Boss {
private Car car;
//構造器要用的元件,都是從容器中獲取
public Boss(@Autowired Car car){
this.car = car;
System.out.println("Boss...有參構造器");
}
/**
* @Bean標註的方法建立物件的時候,方法引數的值從容器中獲取
* @param car
* @return
*/
@Bean
public Color color(Car car){
Color color = new Color();
color.setCar(car);
return color;
}
自動裝配[email protected]根據環境註冊bean
Profile:Spring為我們提供的可以根據當前環境,動態的啟用和切換一系列元件的功能;
@Profile
:指定元件在哪個環境的情況下才能被註冊到容器中,不指定,任何環境下都能註冊這個元件
- 加了環境標識的bean,只有這個環境被啟用的時候才能註冊到容器中。預設是default環境
- 2寫在配置類上,只有是指定的環境的時候,整個配置類裡面的所有配置才能開始生效
- 3沒有標註環境標識的bean在,任何環境下都是載入的;
/**
*
* 開發環境、測試環境、生產環境;
* 資料來源:(/A)(/B)(/C);
*
*
*
*
*/
@PropertySource("classpath:/dbconfig.properties")
@Configuration
public class MainConfigOfProfile implements EmbeddedValueResolverAware{
@Value("${db.user}")
private String user;
private StringValueResolver valueResolver;
private String driverClass;
@Bean
public Yellow yellow(){
return new Yellow();
}
@Profile("test") // 在test環境下才會將這個Bean載入到容器中
@Bean("testDataSource")
public DataSource dataSourceTest(@Value("${db.password}")String pwd) throws Exception{
ComboPooledDataSource dataSource = new ComboPooledDataSource();
dataSource.setUser(user);
dataSource.setPassword(pwd);
dataSource.setJdbcUrl("jdbc:mysql://localhost:3306/test");
dataSource.setDriverClass(driverClass);
return dataSource;
}
@Profile("dev")
@Bean("devDataSource")
public DataSource dataSourceDev(@Value("${db.password}")String pwd) throws Exception{
ComboPooledDataSource dataSource = new ComboPooledDataSource();
dataSource.setUser(user);
dataSource.setPassword(pwd);
dataSource.setJdbcUrl("jdbc:mysql://localhost:3306/ssm_crud");
dataSource.setDriverClass(driverClass);
return dataSource;
}
@Profile("prod")
@Bean("prodDataSource")
public DataSource dataSourceProd(@Value("${db.password}")String pwd) throws Exception{
ComboPooledDataSource dataSource = new ComboPooledDataSource();
dataSource.setUser(user);
dataSource.setPassword(pwd);
dataSource.setJdbcUrl("jdbc:mysql://localhost:3306/scw_0515");
dataSource.setDriverClass(driverClass);
return dataSource;
}
@Override
public void setEmbeddedValueResolver(StringValueResolver resolver) {
// TODO Auto-generated method stub
this.valueResolver = resolver;
driverClass = valueResolver.resolveStringValue("${db.driverClass}");
}
}