您好,登錄后才能下訂單哦!
好程序員Java 培訓分享 SpringBoot - 啟動流程一、主程序入口類
Application.class
@SpringBootApplication
public class SpringbootExampleApplication {
public static void main(String[] args) {
SpringApplication.run(SpringbootExampleApplication.class, args);
}
}
特點
該類使用了@SpringBootApplication 修飾
SpringApplication.run 方法 XxxApplication.class 作為參數傳入
注意: 必須是一個使用 @SpringBootApplication 注解類 當你注釋掉該類的時候直接報錯
二、@SpringBootApplication 注解
概要
@SpringBootApplication 注解是 Spring Boot 的核心注解,它是一個組合注解,它的主要作用是標注在某個類上,表示這是一個 Spring Boot 的配置類
等價于
@SpringBootApplication = ( 默認屬性 )@Configuration + @EnableAutoConfiguration + @ComponentScan 。
源碼
@Target(ElementType.TYPE)
@Retention(RetentionPolicy.RUNTIME)
@Inherited
// 配置注解
@SpringBootConfiguration
// 開啟自動注解
@EnableAutoConfiguration
// 類似于 spring 中的自動掃描包
@ComponentScan(excludeFilters = { @Filter(type = FilterType.CUSTOM, classes = TypeExcludeFilter.class),
@Filter(type = FilterType.CUSTOM, classes = AutoConfigurationExcludeFilter.class) })
public @interface SpringBootApplication {
@AliasFor(annotation = EnableAutoConfiguration.class)
Class<?>[] exclude() default {};
@AliasFor(annotation = EnableAutoConfiguration.class)
String[] excludeName() default {};
@AliasFor(annotation = ComponentScan.class, attribute = "basePackages")
String[] scanBasePackages() default {};
@AliasFor(annotation = ComponentScan.class, attribute = "basePackageClasses")
Class<?>[] scanBasePackageClasses() default {};
}
說明
本身就是注解,提供了exclude() 和 excludeName() 兩個注解屬性
@ComponentScan 注解,同時是 @ComponentScan 注解的容器。我們發現 scanBasePackages 和 scanBasePackageClasses 兩個注解屬性上面同樣聲明了 @AliasFor 注解,分別指向了 @ComponentScan 注解的 basePackages 注解屬性和 basePackageClasses 屬性。
聲明了@EnableAutoConfiguration 注解,表明聲明了它的類本身會默認開啟自動配置
聲明了@Configuration 注解,表明聲明了它的類本身也是個配置類。
三、@Configuration
說明
SpringBoot 社區推薦使用基于 JavaConfig 的配置形式 , @Configuration 表示一個 IoC 容器的配置類
配置方式的區別
表達形式
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"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd">
</beans>
JavaConfig 方式
@Configuration
public class DruidConfiguration{
}
注冊Bean
xml 形式注冊
<bean id="dataSource"
class="com.alibaba.druid.pool.DruidDataSource" />
JavaConfig 方式
@Configuration
public class DruidConfiguration{
public DataSource druidDataSource() {
return new DruidDataSource();
}
}
依賴注入
xml 形式注冊
<bean id="securityManager"
class="org.apache.shiro.web.mgt.DefaultWebSecurityManager" />
<property name="cacheManager" ref="cacheManager" />
</bean>
<bean id="cacheManager" class="org.apache.shiro.cache.MemoryConstrainedCacheManager" />
JavaConfig 方式
@Configuration
public class ShiroConfiguration {
@Bean
public SecurityManager securityManager() {
DefaultWebSecurityManager securityManager = new DefaultWebSecurityManager();
securityManager.setCacheManager(cacheManager);
return securityManager;
}
@Bean
public RedisCacheManager cacheManager(CustomRedisManager redisManager) {
RedisCacheManager redisCacheManager = new RedisCacheManager();
redisCacheManager.setRedisManager(redisManager);
return redisCacheManager;
}
}
總結
@Configuration 一定要配合 @Bean 。用來替換 xml 配置文件
@Bean 注解告訴 Spring ,帶有 @Bean 的注解方法將返回一個對象
四、@ComponentScan
作用
@ComponentScan 對應 XML 配置中的元素 @ComponentScan 的功能其實就是自動掃描并加載符合條件的組件
我們可以通過basePackages 等屬性來細粒度的定制 @ComponentScan 自動掃描的范圍,如果不指定,則默認 Spring 框架實現會從聲明 @ComponentScan 所在類的 package 進行掃描
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。