使用註解開發
說明
在spring4之後,想要使用註解形式,必須得要引入aop的包
在配置文件當中,還得要引入一個context約束
<?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
http://www.springframework.org/schema/context/spring-context.xsd">
</beans>
Bean的實現
我們之前都是使用 bean 的標籤進行bean注入,但是實際開發中,我們一般都會使用註解!
1、配置掃描哪些包下的註解
<!--指定註解掃描包-->
<context:component-scan base-package="com.zhonghu.pojo"/>
2、在指定包下編寫類,增加註解
@Component("user")
// 相當於配置文件中 <bean id="user" class="當前註解的類"/>
public class User {
public String name = "冢狐";
}
3、測試
@Test
public void test(){
ApplicationContext applicationContext =
new ClassPathXmlApplicationContext("beans.xml");
User user = (User) applicationContext.getBean("user");
System.out.println(user.name);
}
屬性注入
使用註解注入屬性
1、可以不用提供set方法,直接在直接名上添加@value(“值”)
@Component("user")
// 相當於配置文件中 <bean id="user" class="當前註解的類"/>
public class User {
@Value("冢狐")
// 相當於配置文件中 <property name="name" value="秦疆"/>
public String name;
}
2、如果提供了set方法,在set方法上添加@value(“值”);
@Component("user")
public class User {
public String name;
@Value("冢狐")
public void setName(String name) {
this.name = name;
}
}
衍生註解
我們這些註解,就是替代了在配置文件當中配置步驟而已!更加的方便快捷!
@Component三個衍生註解
爲了更好的進行分層,Spring可以使用其它三個註解,功能一樣,目前使用哪一個功能都一樣。
- @Controller:web層
- @Service:service層
- @Repository:dao層
寫上這些註解,就相當於將這個類交給Spring管理裝配了!
自動裝配註解
- @Autowired:自動裝配通過類型,找不到再找名稱
- 如果其不能唯一自動裝配上屬性,則需要通過@Qualifier(value=“xxx”)
- @Nullable:自動標記了這個註解,說明這個註解可以爲null
- @Resource:自動裝配通過名字,找不到再類型
作用域
@scope
- singleton:默認的,Spring會採用單例模式創建這個對象。關閉工廠 ,所有的對象都會銷燬。
- prototype:多例模式。關閉工廠 ,所有的對象不會銷燬。內部的垃圾回收機制會回收
@Controller("user")
@Scope("prototype")
public class User {
@Value("冢狐")
public String name;
}
小結
XML與註解比較
- XML可以適用任何場景 ,結構清晰,維護方便
- 註解不是自己提供的類使用不了,開發簡單方便,維護困難
xml與註解整合開發 :推薦最佳實踐
- xml管理Bean
- 註解完成屬性注入
- 使用過程中, 可以不用掃描,掃描是爲了類上的註解
<context:annotation-config/>
作用:
- 進行註解驅動註冊,從而使註解生效
- 用於激活那些已經在spring容器裏註冊過的bean上面的註解,也就是顯示的向Spring註冊
- 如果不掃描包,就需要手動配置bean
- 如果不加註解驅動,則注入的值爲null!
基於Java類進行配置
我們現在要完全不使用Spring的xml配置,全權交給java來處理
JavaConfig 原來是 Spring 的一個子項目,它通過 Java 類的方式提供 Bean 的定義信息,在 Spring4 的版本, JavaConfig 已正式成爲 Spring4 的核心功能 。
1、編寫一個實體類,User
// 這個註解的意思就是這個類被Spring接管了,註冊到容器中
@Component
public class User {
private String name;
public String getName() {
return name;
}
@Value("冢狐")
public void setName(String name) {
this.name = name;
}
@Override
public String toString() {
return "User{" +
"name='" + name + '\'' +
'}';
}
}
2、新建一個config配置包,編寫一個MyConfig配置類
// 這個也會Spring容器託管,註冊到容器中,因爲它本身就是一個@Conmponent
// @Configuration代表這是一個配置類,和我們之前看到的beans.xml是一樣的
@Configuration
@ComponentScan("com.zhonghu.pojo")
public class MyConfig {
// 註冊一個bean,就相當於我們之前寫的一個bean標籤
// 這個方法的名字,相當於我們bean標籤中的id
// 這個方法的返回值,相當於我們bean標籤中的class屬性
@Bean
public User getUser(){
// 就是返回要注入的bean的對象
return new User();
}
}
3、測試
public class MyTest {
public static void main(String[] args) {
// 如果我們完成使用了配置類方式去實現,我們就只能通過AnnotationConfig上下文來獲取容器,通過配置類的class來加載對象
ApplicationContext context = new AnnotationConfigApplicationContext(MyConfig.class);
User getUser = (User) context.getBean("getUser");
System.out.println(getUser.getName());
}
}
4、成功輸出結果!
導入其他配置如何做呢?
1、我們再編寫一個配置類!
@Configuration //代表這是一個配置類
public class MyConfig2 {
}
2、在之前的配置類中我們來選擇導入這個配置類
@Configuration
@Import(MyConfig2.class) //導入合併其他配置類,類似於配置文件中的 inculde 標籤
public class MyConfig {
@Bean
public Dog dog(){
return new Dog();
}
}
public class MyConfig2 {
}
2、在之前的配置類中我們來選擇導入這個配置類
@Configuration
@Import(MyConfig2.class) //導入合併其他配置類,類似於配置文件中的 inculde 標籤
public class MyConfig {
@Bean
public Dog dog(){
return new Dog();
}
}
關於這種Java類的配置方式,我們在之後的SpringBoot 和 SpringCloud中還會大量看到,我們需要知道這些註解的作用即可!