文章目錄
- SpringBoot容器功能及注解超詳解🎉🎉🎉
- 1.組件添加
- 1.1@Configuration
- 1.2@Import
- 1.3@Conditional
- 2.原生組態檔引入
- 2.1@ImportResource
- 3.配置系結
- 3.1@ConfigurationProperties
- 3.2@EnableConfigurationProperties + @ConfigurationProperties
SpringBoot容器功能及注解超詳解🎉🎉🎉
1.組件添加
1.1@Configuration
@Configuration:告訴SpringBoot這是一個配置類
-
配置類里面使用
@Bean標注在方法上給容器注冊組件,默認也是單實體的 -
配置類本身也是組件
-
proxyBeanMethods:代理bean的方法- Full(
proxyBeanMethods = true):保證每個@Bean方法被呼叫多少次回傳的組件都是單實體的 - Lite(
proxyBeanMethods = false):每個@Bean方法被呼叫多少次回傳的組件都是新創建的 - 組件依賴必須使用Full模式默認,其他默認是否Lite模式
最佳實戰:
- 配置類組件之間無依賴關系用Lite模式加速容器啟動程序,減少判斷
- 配置類組件之間有依賴關系,方法會被呼叫得到之前單實體組件,用Full模式
- Full(
代碼實戰演示:
@Configuration(proxyBeanMethods = false)//告訴SpringBoot這是一個配置類=組態檔
public class MyConfig {
@Bean//給容器中添加組件,以方法名作為組件的id,回傳型別就是組件型別,回傳的值,就是組件在容器中的實體
public User user01() {
User zhangsan = new User("zhangsan", 18);
return zhangsan;
}
@Bean("tom")//也可以自己設定id代替方法名作為id
public Pet tomcatPet() {
return new Pet("tomcat");
}
}
@SpringBootApplication
public class Boot01HelloworldApplication {
public static void main(String[] args) {
ConfigurableApplicationContext run = SpringApplication.run(Boot01HelloworldApplication.class, args);
MyConfig bean = run.getBean(MyConfig.class);
System.out.println(bean);//com.atguigu.boot.config.MyConfig@d67d8
//如果@Configuration(proxyBeanMethods = true)代理物件呼叫方法,SpringBoot總會檢查這個組件是否在容器中有,
//保持組件單實體
User user = bean.user01();
User user1 = bean.user01();
//(proxyBeanMethods = true)回傳true
//(proxyBeanMethods = false)回傳false
System.out.println(user == user1);
}
}
如果有組件依賴:
@Configuration(proxyBeanMethods = true)//告訴SpringBoot這是一個配置類=組態檔
public class MyConfig {
@Bean//給容器中添加組件,以方法名作為組件的id,回傳型別就是組件型別,回傳的值,就是組件在容器中的實體
public User user01() {
User zhangsan = new User("zhangsan", 18);
//user組件依賴了Pet組件
zhangsan.setPet(tomcatPet());
return zhangsan;
}
@Bean("tom")//也可以自己設定id代替方法名作為id
public Pet tomcatPet() {
return new Pet("tomcat");
}
}
@SpringBootApplication
public class Boot01HelloworldApplication {
public static void main(String[] args) {
ConfigurableApplicationContext run = SpringApplication.run(Boot01HelloworldApplication.class, args);
MyConfig bean = run.getBean(MyConfig.class);
System.out.println(bean);
User user01 = run.getBean("user01", User.class);
Pet tom = run.getBean("tom", Pet.class);
//(proxyBeanMethods = true)回傳(用戶的寵物:true)
//(proxyBeanMethods = false)回傳(用戶的寵物:false)
System.out.println("用戶的寵物:"+(user01.getPet() == tom));
}
}
1.2@Import
@Import:給容器中匯入組件
代碼演示:
//給容器中自動無參構造創建出這兩個型別的組件、默認組件的名字就是全類名
@Import({User.class, DBHelper.class})
@Configuration(proxyBeanMethods = false) //告訴SpringBoot這是一個配置類 == 組態檔
public class MyConfig {
}
@SpringBootApplication
public class Boot01HelloworldApplication {
public static void main(String[] args) {
ConfigurableApplicationContext run = SpringApplication.run(Boot01HelloworldApplication.class, args);
//獲取組件
String[] beanNamesForType = run.getBeanNamesForType(User.class);
for (String s : beanNamesForType) {
System.out.println(s);
}
DBHelper bean = run.getBean(DBHelper.class);
System.out.println(bean);
}
}
//輸出:
com.atguigu.boot.bean.User
ch.qos.logback.core.db.DBHelper@16ef799
1.3@Conditional
@Conditional:條件裝配,滿足Conditional指定的條件,則進行組件注入
有一系列派生注解:

2.原生組態檔引入
2.1@ImportResource
原生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:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context https://www.springframework.org/schema/context/spring-context.xsd">
<bean id="haha" class="com.atguigu.boot.bean.User">
<property name="name" value="zhangsan"></property>
<property name="age" value="18"></property>
</bean>
<bean id="hehe" class="com.atguigu.boot.bean.Pet">
<property name="name" value="tomcat"></property>
</bean>
</beans>
自定義配置類:
@Configuration(proxyBeanMethods = true)//告訴SpringBoot這是一個配置類=組態檔
@ImportResource("classpath:beans.xml")
public class MyConfig {
}
測驗:
@SpringBootApplication
public class Boot01HelloworldApplication {
public static void main(String[] args) {
ConfigurableApplicationContext run = SpringApplication.run(Boot01HelloworldApplication.class, args);
boolean haha = run.containsBean("haha");
boolean hehe = run.containsBean("hehe");
System.out.println(haha);//true
System.out.println(hehe);//true
}
}
3.配置系結
如何使用Java讀取到properties檔案中的內容,并且把它封裝到JavaBean中,以供隨時使用;
原生方法(組態檔復雜就顯得麻煩):
public class getProperties {
public static void main(String[] args) throws FileNotFoundException, IOException {
Properties pps = new Properties();
pps.load(new FileInputStream("a.properties"));
Enumeration enum1 = pps.propertyNames();//得到組態檔的名字
while(enum1.hasMoreElements()) {
String strKey = (String) enum1.nextElement();
String strValue = pps.getProperty(strKey);
System.out.println(strKey + "=" + strValue);
//封裝到JavaBean,
}
}
}
3.1@ConfigurationProperties
組態檔:
mycar.brand=BYD
mycar.price=100000
創建一個car類:
//只有在容器中的組件,才會擁有SpringBoot提供的強大功能
@Component
@ConfigurationProperties(prefix = "mycar")
//Lombok注解簡化開發
@Data
@NoArgsConstructor
@ToString
@AllArgsConstructor
public class Car {
private String brand;
private Integer price;
}
測驗方法:
@RestController
public class HelloController {
@Autowired
Car car;
@RequestMapping("/car")
public Car car(){
return car;
}
}
測驗結果:

3.2@EnableConfigurationProperties + @ConfigurationProperties
@EnableConfigurationProperties必須在配置類里寫:
@Configuration(proxyBeanMethods = true)//告訴SpringBoot這是一個配置類=組態檔
@EnableConfigurationProperties(Car.class)
//1.開啟Car屬性配置系結功能
//2.把Car這個組件自動注冊到容器中
public class MyConfig {
}
該寫法就不用在寫@Component
@ConfigurationProperties(prefix = "mycar")
@Data
@NoArgsConstructor
@ToString
@AllArgsConstructor
public class Car {
private String brand;
private Integer price;
}
最后喜歡的小伙伴別忘了一鍵三連哦🎈🎈🎈

轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/302224.html
標籤:java
上一篇:Java---繼承
