Spring純註解配置實現程式碼示例解析
問題
我們發現,之所以我們現在離不開 xml 配置檔案,是因為我們有一句很關鍵的配置:
<!-- 告知spring框架在,讀取配置檔案,建立容器時,掃描註解,依據註解建立物件,並存入容器中 -->
<context:component-scan base-package="com.itheima"></context:component-scan>
如果他要也能用註解配置,那麼我們就離脫離 xml 檔案又進了一步。
另外,資料來源和 JdbcTemplate 的配置也需要靠註解來實現。
<!-- 配置 dbAssit -->
<bean id="dbAssit" class="com.itheima.dbassit.DBAssit"><property name="dataSource" ref="dataSource"></property>
</bean>
<!-- 配置資料來源 -->
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<property name="driverClass" value="com.mysql.jdbc.Driver"></property>
<property name="jdbcUrl" value="jdbc:mysql:///spring_day02"></property><property name="user" value="root"></property>
<property name="password" value="1234"></property>
</bean>
新註解說明
@Configuration
作用:
用於指定當前類是一個 spring 配置類,當建立容器時會從該類上載入註解。獲取容器時需要使用
AnnotationApplicationContext(有@Configuration 註解的類.class)。
屬性:
value:用於指定配置類的位元組碼
例項:
示例程式碼:
/** * spring 的配置類,相當於 bean.xml 檔案 * @author * @Company * @Version 1.0 */ @Configuration public class SpringConfiguration { }
注意:
我們已經把配置檔案用類來代替了,但是如何配置建立容器時要掃描的包呢?
請看下一個註解。
@ComponentScan
作用:
用於指定 spring 在初始化容器時要掃描的包。作用和在 spring 的 xml 配置檔案中的:
<context:component-scan base-package="com.itheima"/>是一樣的。
屬性:
basePackages:用於指定要掃描的包。和該註解中的 value 屬性作用一樣。
示例程式碼:
/** * spring 的配置類,相當於 bean.xml 檔案 * @author * @Company * @Version 1.0 */ @Configuration @ComponentScan("com.itheima") public class SpringConfiguration { }
注意:
我們已經配置好了要掃描的包,但是資料來源和 JdbcTemplate 物件如何從配置檔案中移除呢?
請看下一個註解。
@Bean
作用:
該註解只能寫在方法上,表明使用此方法建立一個物件,並且放入 spring 容器。
屬性:
name:給當前@Bean 註解方法建立的物件指定一個名稱(即 bean 的 id)。
/** * 連線資料庫的配置類 * @author * @Company * @Version 1.0 */ public class JdbcConfig { /** * 建立一個數據源,並存入 spring 容器中 * @return */ @Bean(name="dataSource") public DataSource createDataSource() { try { ComboPooledDataSource ds = new ComboPooledDataSource(); ds.setUser("root"); ds.setPassword("1234"); ds.setDriverClass("com.mysql.jdbc.Driver"); ds.setJdbcUrl("jdbc:mysql:///spring_day02"); return ds; } catch (Exception e) { throw new RuntimeException(e); } } /** * 建立一個 DBAssit,並且也存入 spring 容器中 * @param dataSource * @return */ @Bean(name="runner") @Scope("prototype") //配置QueryRunner為多列物件 防止多個dao呼叫使執行緒混亂 public QueryRunner createDBAssit(DataSource dataSource) { return new DBAssit(dataSource); } }
注意:
我們已經把資料來源和 DBAssit 從配置檔案中移除了,此時可以刪除 bean.xml 了。
但是由於沒有了配置檔案,建立資料來源的配置又都寫死在類中了。如何把它們配置出來呢?
請看下一個註解。
@PropertySource
用於載入.properties 檔案中的配置。例如我們配置資料來源時,可以把連線資料庫的資訊寫到properties 配置檔案中,就可以使用此註解指定 properties 配置檔案的位置。
屬性:
value[]:用於指定 properties 檔案位置。如果是在類路徑下,需要寫上 classpath:
配置:
/** * 連線資料庫的配置類 * @author 黑馬程式設計師 * @Company http://www.ithiema.com * @Version 1.0 */ public class JdbcConfig { @Value("${jdbc.driver}") private String driver; @Value("${jdbc.url}") private String url; @Value("${jdbc.username}") private String username; @Value("${jdbc.password}") private String password; /** * 建立一個數據源,並存入 spring 容器中 * @return */ @Bean(name="dataSource") public DataSource createDataSource() { try { ComboPooledDataSource ds = new ComboPooledDataSource(); ds.setDriverClass(driver); ds.setJdbcUrl(url); ds.setUser(username); ds.setPassword(password); return ds; } catch (Exception e) { throw new RuntimeException(e); } } } jdbc.properties 檔案: jdbc.driver=com.mysql.jdbc.Driver jdbc.url=jdbc:mysql://localhost:3306/day44_ee247_spring jdbc.username=root jdbc.password=1234
注意:
此時我們已經有了兩個配置類,但是他們還沒有關係。如何建立他們的關係呢?
請看下一個註解。
@Import
作用:
用於匯入其他配置類,在引入其他配置類時,可以不用再寫@Configuration 註解。當然,寫上也沒問
題。
屬性:
value[]:用於指定其他配置類的位元組碼。
示例程式碼:
@Configuration @ComponentScan(basePackages = "com.itheima.spring") @Import({ JdbcConfig.class}) public class SpringConfiguration { } @Configuration @PropertySource("classpath:jdbc.properties") public class JdbcConfig{ }
通過註解獲取容器:
ApplicationContext ac =new AnnotationConfigApplicationContext(SpringConfiguration.class);
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。