spring-boot之di、javaConfig形式管理注入Bean(1)
阿新 • • 發佈:2019-02-01
spring相關
1.依賴注入:容器負責建立物件和維護物件之間的依賴關係,而不是通過物件本身負責自己的建立和解決自己的依賴
2.spring IoC容器(ApplicationContext)負責建立bean,並通過容器將功能能類bean注入到你需要的bean中,
xml、註解、grovy配置實現Bean的建立和注入。無論事哪種都被稱為配置元資料,元資料即描述資料的資料。元資料本事不具備
任何可執行的能力,只能通過外界程式碼來對這些元資料解析後進行一些有意義的操作。spring將這些配置元資料進行Bean初始化、
配置和管理依賴。
宣告Bean的註解:
@componet元件:沒有明確的角色
@Service在業務邏輯層使用
@Repository在資料訪問層使用
@Controller在展示層使用(mvc)
注入Bean的註解
@utowired:Spring提供的註解
@Inject:-330提供的註解
@Resource:JSR-250提供的註解
可註解在set方法上或者屬性上
di方式
package com.zh.ch1.di; import org.springframework.stereotype.Service; /** * 編寫功能類的Bean * @author Hiiso * */ @Service /** * @Service:聲明當前FunctionService類是Spring管理的一個Bean * @author Hiiso * */ public class FunctionService { public String syaHello(String word){ return "hello"+word+"!"; } }
package com.zh.ch1.di; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Controller; /** * 使用功能類的Bean * * @author Hiiso * */ @Controller public class UseFunctionService { @Autowired /** * @Autowired 將FunctionService實體Bean注入到UseFunctionService(當前Bean)中 * 等效@Inject:-330提供的註解、@Resource:JSR-250提供的註解 */ FunctionService functionService; public String SayHello(String word) { return functionService.syaHello(word); } }
package com.zh.ch1.di;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
/**
* @Configuration:聲明當前類是一個配置類
* @author Hiiso
*
*/
@Configuration
/**
* @ComponentScan:指定掃描包下的所有註解類(@Service、等)並註冊為Spring可管理的Bean
* @author Hiiso
*
*/
@ComponentScan("com.zh.ch1.di")
public class DiConfig {
}
package com.zh.ch1.di;
import org.springframework.context.annotation.AnnotationConfigApplicationContext;
public class Main {
public static void main(String[] args) {
AnnotationConfigApplicationContext context=new AnnotationConfigApplicationContext(DiConfig.class);
UseFunctionService useFunctionService=context.getBean(UseFunctionService.class);
System.out.println(useFunctionService.SayHello("--di"));
context.close();
}
}
結果:hello--di!
javaConfig方式
package com.zh.ch1.javaconfig;
/**
* @author Hiiso
*此處沒有註解
*/
public class FunctionService {
public String syaHello(String word){
return "hello"+word+"!";
}
}
package com.zh.ch1.javaconfig;
/**
* @author Hiiso
*此處沒有註解
*/
public class UseFunctionService {
FunctionService functionService;
public void setFunctionService(FunctionService functionService) {
this.functionService = functionService;
}
public String SayHello(String word) {
return functionService.syaHello(word);
}
}
package com.zh.ch1.javaconfig;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
@Configuration//1
/**
* @author Hiiso
*1:@Configuration:指定該類事一個配置類,該類意味著這個類包含了0個或多個@bean註解
*2:@Bean:返回值是一個Bean,Bean的名稱是一個方法名(供其他有需要的Bean進行注入)
*3:注入FunctionService的Bean時候直接呼叫functionService((帶返回值的bean--functionService()))
*4:另一種注入方式,在spring容器中,只要存在某個Bean,就可以在另一個Bean作為引數注入
*/
public class JavaConfig {
@Bean//2
public FunctionService functionService(){
return new FunctionService();
}
/*@Bean
public UseFunctionService useFunctionService(){
UseFunctionService useFunctionService=new UseFunctionService();
useFunctionService.setFunctionService(functionService());//3
return useFunctionService;
}*/
//4:另一種注入方式
@Bean
public UseFunctionService useFunctionService(FunctionService functionService){//4
UseFunctionService useFunctionService=new UseFunctionService();
useFunctionService.setFunctionService(functionService);
return useFunctionService;
}
}
package com.zh.ch1.javaconfig;
import org.springframework.context.annotation.AnnotationConfigApplicationContext;
public class JavaConfigMain {
public static void main(String[] args) {
AnnotationConfigApplicationContext context=new AnnotationConfigApplicationContext(JavaConfig.class);
UseFunctionService useFunctionService=context.getBean(UseFunctionService.class);
System.out.println(useFunctionService.SayHello("--java Config"));
context.close();
}
}
結果:hello--java
Config!